1.string–>Byte[]转换
①String类型转换为UTF8编码的Byte[]:
string strvalue ="00123aabbAA$%";
byte[] byteArray = System.Text.Encoding.UTF8.GetBytes(strvalue);
②string类型转换为ASCII编码的Byte[]:
string strvalue ="00123aabbAA$%";
byte[] byteArray = System.Text.Encoding.ASCII.GetBytes (strvalue);
③string类型转换为GB18030编码的Byte[];
string strvalue ="00123aabbAA$%":
byte[] byteArray = System.Text.Encoding.GetEncoding("GB18030").GetBytes (strvalue);
2.Byte[]–>string转换
①UTF8编码的Byte[]转换为String类型:
byte[] byteArray = new byte[100];
String str = System.Text.Encoding.UTF8.GetString ( byteArray );
②ASCII编码的Byte[]转换为String类型:
byte[] byteArray = new byte[100];
String str = System.Text.Encoding.ASCII.GetString ( byteArray );
③GB18030编码的Byte[]转换为String类型:
byte[] byteArray = new byte[100];
String str = System.Text.Encoding.GetEncoding("GB18030").GetString ( byteArray );
下面对上面的类型转换,举例说明:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace TRansfer
{
class Program
{
static void Main(string[] args)
{
string strvalue = "0aA$%#@!%^&*_+-=中国";
byte[] byteArray1 = System.Text.Encoding.UTF8.GetBytes(strvalue);
byte[] byteArray2 = System.Text.Encoding.ASCII.GetBytes(strvalue);
byte[] byteArray3 = System.Text.Encoding.GetEncoding("GB18030").GetBytes(strvalue);
byte[] byteArray11 = new byte[100];
String str1 = System.Text.Encoding.UTF8.GetString(byteArray1);
String str2 = System.Text.Encoding.ASCII.GetString(byteArray2);
String str3 = System.Text.Encoding.GetEncoding("GB18030").GetString(byteArray3);
string st1 = "";
foreach (byte b in byteArray1)
{
st1 += b.ToString();
}
string st2 = "";
foreach (byte b in byteArray2)
{
st2 += b.ToString();
}
string st3 = "";
foreach (byte b in byteArray3)
{
st3 += b.ToString();
}
Console.WriteLine("{0} {1}", st1, str1);
Console.WriteLine("{0} {1}", st2, str2);
Console.WriteLine("{0} {1}", st3, str3);
}
}
}
测试结果如下,对英文字符的翻译都是一致,各种不同的编码的差别主要体现在中文上面: