本文主要是介绍C# 字节数组 byte[] 关于byte的小寄巧 以及Encoding和BitConverter,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
怎么读字节数组里面的内容
- 先是小错误 之 ToString
- 然后是怎么办
- 使用UTF-8编码
- 使用ASCII编码
- 使用其他编码
- 未知编码
- 注意
- 小demo
- 下一个demo
- 关于发送端的(发送新行)
- 手搓bug编码
- 之搓`ascii encodeing`
- 评价为不如`BitConverter`一根
先是小错误 之 ToString
在C#
中,dataTemp
很可能是一个字节数组(byte[]
),因为你正在尝试将它转换为字符串。这两个语句的主要区别在于它们如何解释dataTemp中的字节以生成字符串。
string str = Encoding.GetEncoding("GB2312").GetString(dataTemp);
receive_tb.AppendText(str);
这个语句首先使用GB2312
编码来解码dataTemp
字节数组。GB2312
是一个用于简体中文字符的编码方式,如果你的数据是以GB2312
编码的,那么这将正确地将字节转换为字符串。然后,这个字符串被添加到receive_tb
(很可能是一个文本框控件)中。
receive_tb.AppendText(dataTemp.ToString());
这个语句会尝试调用dataTemp
数组的ToString
方法,但这不会将字节数组的内容转换为字符串。实际上,对于数组类型,ToString
方法通常返回数组类型的名称以及元素的数量,而不是数组内容的文本表示。例如,如果dataTemp
是一个包含几个字节的数组,那么dataTemp.ToString()
可能会返回类似于System.Byte[]
这样的字符串,而不是字节的实际内容。
因此,这两个语句的效果完全不同。第一个语句会按照GB2312
编码将字节转换为字符串并显示,而第二个语句只会显示数组的类型和大小信息,而不是数组的实际内容。
如果你想要以某种方式显示dataTemp
的内容,你需要确保你以正确的方式将其转换为字符串。这通常涉及选择一个适当的编码来解码字节。如果你不确定数据的编码方式,你可能需要查看文档或询问数据的来源以确定正确的编码。如果你只是想以十六进制或其他格式显示字节,你需要编写额外的代码来实现这一点。
然后是怎么办
在C#
中,将字节数组转换为字符串通常取决于字节数组所代表的编码。如果字节数组包含的是文本数据,并且你知道它的编码方式(例如UTF-8
、ASCII
、GB2312
等),你可以使用Encoding
类来将字节转换为字符串。以下是一些常见的转换方法:
C# 关于Encoding编码 举例UTF8
使用UTF-8编码
byte[] dataTemp = ... // 你的字节数组
string str = Encoding.UTF8.GetString(dataTemp);
使用ASCII编码
如果你的数据是ASCII文本:
byte[] dataTemp = ... // 你的字节数组
string str = Encoding.ASCII.GetString(dataTemp);
使用其他编码
对于GB2312或其他编码,你可以这样做:
byte[] dataTemp = ... // 你的字节数组
string str = Encoding.GetEncoding("GB2312").GetString(dataTemp);
未知编码
如果你不确定数据的编码,你可能需要尝试不同的编码,或者查看数据的文档或来源以确定正确的编码。
注意
如果字节数组包含非文本数据(例如图像、音频或二进制文件的一部分),那么将其转换为字符串可能没有意义,因为结果可能不是人类可读的。
在处理文本数据时,始终最好知道数据的编码,因为错误的编码会导致乱码或数据丢失。
在某些情况下,你可能需要处理字节顺序标记(BOM
),这通常在UTF-16
或UTF-32
编码的文本中出现。Encoding
类通常能够处理这些情况,但了解这一点很重要,特别是当你处理来自不同来源的文本数据时。
异常处理
当处理字节到字符串的转换时,可能会出现异常,特别是当字节数组包含无效的编码序列时。为了避免程序崩溃,你可以使用try-catch
块来捕获并处理这些异常:
byte[] dataTemp = ... // 你的字节数组
string str;
try
{ str = Encoding.UTF8.GetString(dataTemp);
}
catch (DecoderFallbackException ex)
{ // 处理解码异常,例如记录错误或提供默认值 str = "解码错误";
}
在这个例子中,如果解码过程中发生异常,程序会捕获DecoderFallbackException
异常,并给str
赋一个默认值或采取其他适当的措施。
小demo
using System;class TODO
{public static void Main(string[] args){byte myByte = 0x10; // 二进制表示为 10100101 string str = myByte.ToString(); // 输出 "A5"Console.Write(str);}
}
16
下一个demo
//string str = Encoding.GetEncoding("GB2312").GetString(dataTemp);
//str = str.Replace("\0", "\\0");//0x00 \0 结束 不显示的,现在将他显示
//receive_tb.AppendText(str);foreach(byte i in dataTemp) {receive_tb.AppendText(Convert.ToChar(i).ToString());
}
//receive_tb.AppendText(dataTemp.ToString());//见博客字节数组
我也是闲的,将byte
变成char
再变成string
输出
关于发送端的(发送新行)
foreach (byte i in dataTemp) {receive_tb.AppendText(Convert.ToString(i, 16));
}
关于为啥会在接收到我发送的内容后又接收到13
和10
(都是10进制
)
这其实是换行和回车的ascii
(\r\n
)
手搓bug编码
之搓ascii encodeing
if (dataTemp.Length == 1) {receive_tb.AppendText(Convert.ToString(dataTemp[0], 16));} else if (dataTemp.Length == 2) {if (dataTemp[0] == 13 && dataTemp[1] == 10) {receive_tb.AppendText("\r\n");} else {receive_tb.AppendText(Convert.ToString(dataTemp[0], 16));receive_tb.AppendText(Convert.ToString(dataTemp[1], 16));}} else if (dataTemp.Length > 3) {for (int i = 0; i < dataTemp.Length - 2; i++) {receive_tb.AppendText(Convert.ToString(dataTemp[i], 16));}if (dataTemp[dataTemp.Length - 2] == 13 && dataTemp[dataTemp.Length - 1] == 10) {receive_tb.AppendText("\r\n");} else {receive_tb.AppendText(Convert.ToString(dataTemp[dataTemp.Length - 2], 16));receive_tb.AppendText(Convert.ToString(dataTemp[dataTemp.Length - 1], 16));}
}
评价为不如BitConverter
一根
C# BitConverter
string str = BitConverter.ToString(dataTemp).Replace("-", " ");
receive_tb.AppendText(str);
这篇关于C# 字节数组 byte[] 关于byte的小寄巧 以及Encoding和BitConverter的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!