时间:2023-01-18 11:01:13 | 栏目:.NET代码 | 点击:次
byte[] data = BitConverter.GetBytes('哈'); Console.Write(data);//200,84 (两个字节) Console.Write(BitConverter.GetBytes('1'));//49,0 (两个字节) Console.Write(BitConverter.GetBytes(258));//2,1,0,0 (整数,32位,四个字节) Console.Write(BitConverter.GetBytes(1.2));//8个元素 (八个字节) Console.Write(BitConverter.GetBytes(true));//1 (一个字节)
char str = BitConverter.ToChar(new byte[] { 200, 84 }, 0); Console.Write(str);//哈 short sho = BitConverter.ToInt16(new byte[] { 69, 0 }, 0); Console.Write(sho.ToString());//69
string strHex = BitConverter.ToString(new byte[] { 09, 45, 65, 0, 0 }); Console.Write(strHex);//09-2D-41-00-00 string strHex = BitConverter.ToString(new byte[] { 69, 0, 0, 0, 0 }); Console.Write(strHex);//45-00-00-00-00
注意:跟BitConverter.IsLittleEndian属性有关,true表示最大的有效字节位于单词的右端。
整数 | 对应的十六进制数 |
转成字节数组byte[] BitConverter.GetBytes(**) |
字节数据每个字节对应的十六进制表示 |
---|---|---|---|
1 | 1:0x01 (两位两位地对齐) | [1,0,0,0] | 01- 00- 00 -00 |
65540 | 10004:0x1 00 04 (两位两位地对齐) | [4,0,1,0] | 04- 00- 01 -00 |
999999999 | 3B9AC9FF:0x3B9AC9FF (两位两位地对齐) | [255,201,154,59] | FF -C9- 9A -3B |
一个ASCII码占一个字节,其中一个为检验位。共27=128个字符,只适合所有的拉丁字母。
Console.Write(Convert.ToByte('a'));//97 Console.Write((int)'a');//97,强制转换 Console.Write(Convert.ToByte('1'));//49 Console.Write((int)'1');//49
Convert.ToChar(97)=>'d'; (char)97='a' --强制转换:
注意:C#中的Char字符类型为Unicode类型,每个字符占2个字节。
void Main() { Console.WriteLine(StrToHex("哈啊a的1我z!")); Console.WriteLine(HexToStr("B9 FE B0 A1 61 B5 C4 31 CE D2 7A 21")); } //字符串转换成十六进制字符串 public string StrToHex(string mStr) { return BitConverter.ToString(ASCIIEncoding.Default.GetBytes(mStr)).Replace("-", " "); } // 十六进制字符串转换成字符串 public string HexToStr(string mHex) { mHex = mHex.Replace(" ", ""); if (mHex.Length <= 0) return ""; byte[] vBytes = new byte[mHex.Length / 2]; for (int i = 0; i < mHex.Length; i += 2) if (!byte.TryParse(mHex.Substring(i, 2), NumberStyles.HexNumber, null, out vBytes[i / 2])) vBytes[i / 2] = 0; return ASCIIEncoding.Default.GetString(vBytes); }
BitArray类用来处理位集合。位集合是可以用来有效表示Boolean值的集合。注意:表示True/False的集合,不是0、1集合。
如:对常规数的二进制的显示或存储:
0 0 0 0 0 0 0 1
而对于在BitArray里的存储,它是如下格式:
True False False False False False False False
它的顺序是相反的,而且用布尔值很难便捷读懂,但实际上,我们应当把数值当作1和0这样直观的显示出来,并且顺序也要进行处理!
解决方法:BitArray里显示的格式是逆序的,并且每一位都用布尔值显示,我们无法改变BitArray类所用的内部代码,但我们可以编写外部代码,使它能够更加友好的便于理解的常规的方式显示出来。
下面创建一个字节数组,里面包含5个byte。
int bits; string[] binNumber = new string[8];// int binary; byte[] ByteSet = new byte[] { 1, 2, 3, 4, 5 };//定义一个字节型数组,存5个字节型数值:1,2,3,4,5,6 BitArray BitSet = new BitArray(ByteSet);//这里一定要注意,这里的每一个字节型数值是以位的形式、每一位用Boolean值、逆序存储在BitArray(1字节对应8位) bits = 0;//bits是计数器,到8了就又归为初始值0;为的是方便知道操作完了一个字节型数值(1字节正好占8位) binary = 7;//binary是二进制数组下标索引;初始值为7,这是因为BitArray里存储的数据和常规二进制数据的顺序是相反的 Console.WriteLine("BitSet里包含的元素数" + BitSet.Count);//40,因为数据在BitArray里是以位的形式存储的,5个字节型数值,一个字节占8位,所以共占40位!!!不是5!!! for (int i = 0; i <= BitSet.Count - 1; i++)//遍历40个位,每个位存boolean值True/False { Console.WriteLine("BitSet.Get(" + i + ")" + BitSet.Get(i)); if (BitSet.Get(i) == true) binNumber[binary] = "1";//如果该位存储的true值,则转成1; else binNumber[binary] = "0";//如果该位存储的false值,则转成0; bits++; //计数+1 binary--; //eg.第8位(下标7)存好,则将下标向左移1位存下一轮将位布尔值转成的二进制0/1 if ((bits % 8) == 0)//当计数器为8时,表示一个字节型的数值已经表示完全了 { binary = 7;//将存储字节型数值的二进制形式的String型数组的下标归初始 bits = 0; for (int j = 0; j <= 7; j++) Console.Write(binNumber[j]); Console.WriteLine(); } }
结果:
取整型数组来试一试,整型数组是4字节,32位
int bits = 0; int index = 31; string[] s = new string[32]; int[] a = new int[] { 2, 3, 2, 7, 2147483647 }; BitArray BA = new BitArray(a); Console.WriteLine("BA的大小:" + BA.Count); //5*4*8=160 for (int i = 0; i < BA.Count; i++) { Boolean b = BA.Get(i); if (b == true) s[index] = "1"; else s[index] = "0"; bits++; index--; if (bits % 32 == 0) //每隔一个数字(4*8)换行 { bits = 0; index = 31; for (int j = 0; j <= 31; j++) Console.Write(s[j]); Console.WriteLine(); } }
结果: