1. string -> byte[]
2. byte[] -> string
注:采用Unicode而不是Default,主要是因为C#中string的存储格式就是Unicode的标准形式,一个字符占用两个字节。当然具体怎么转换取决你的思路,Default采用最节省空间的方式。
这种方法是标准的方法,肯定正确,但是不够快。可以采用unsafe的方法提高效率。具体做法如下:
1. string -> byte[]
fixed (char* str = var) //var is string
{
fixed (byte* ptr = data) //data is byte[]
{
byte* bstr = (byte*)str; //---------------------1
for (int i = 0; i < var.Length * 2; i++)
{
ptr[i++] = bstr[i];
}
}
}2. byte[] -> string
char[] tvar = new char[length / 2];
fixed (char* str = tvar)
{
fixed (byte* ptr = data)
{
byte* pstr = (byte*)str; //-----------------------2
for (int i = 0; i < data.Length; i++)
{
pstr[i] = ptr[i];
}
}
}
string var = new string(tvar);注意:a. 在string中,每个字符占两个字节,所以转换成byte数组时,长度要注意乘以2,反之除以2
经过测试,对一个简单的中英文混合的字符串转换1000000次,写字符串要快10倍,读字符串大约只快2倍,这是由于最后创建string对象造成的。
本文介绍C#中string与byte数组之间的快速转换方法。通过使用unsafe代码块及指针操作,实现比标准方法更快的转换速度,特别是在大量字符串处理时效果显著。
747

被折叠的 条评论
为什么被折叠?



