C#代码如下:
求解释:int i = (short)(array[0]-'\0') * 256 + ((short)(array[1]-'\0'));
有什么计算规律?
public static string GetPYString(string str)
{
string tempStr = "";
foreach (char c in str)
{
if ((int)c >= 33 && (int)c <= 126)
{//字母和符号原样保留
tempStr += c.ToString();
}
else
{//累加拼音声母
tempStr += GetPYChar(c.ToString());
}
}
return tempStr;
}
/// <summary>
///
/// </summary>
/// <param name="c"></param>
/// <returns>拼音声母</returns>
public static string GetPYChar(string c)
{
byte[] array = new byte[2];
array = System.Text.Encoding.Default.GetBytes(c);
int i = (short)(array[0]-'\0') * 256 + ((short)(array[1]-'\0'));
if (i < 0xB0A1) return "*";
if (i < 0xB0C5) return "a";
if (i < 0xB2C1) return "b";
if (i < 0xB4EE) return "c";
if (i < 0xB6EA) return "d";
if (i < 0xB7A2) return "e";
if (i < 0xB8C1) return "f";
if (i < 0xB9FE) return "g";
if (i < 0xBBF7) return "h";
if (i < 0xBFA6) return "g";
if (i < 0xC0AC) return "k";
if (i < 0xC2E8) return "l";
if (i < 0xC4C3) return "m";
if (i < 0xC5B6) return "n";
if (i < 0xC5BE) return "o";
if (i < 0xC6DA) return "p";
if (i < 0xC8BB) return "q";
if (i < 0xC8F6) return "r";
if (i < 0xCBFA) return "s";
if (i < 0xCDDA) return "t";
if (i < 0xCEF4) return "w";
if (i < 0xD1B9) return "x";
if (i < 0xD4D1) return "y";
if (i < 0xD7FA) return "z";
return "*";
}
byte[] array = new byte[2];
声明一个两位的byte数组,因为一个汉字占两个字符.
array = System.Text.Encoding.Default.GetBytes(c);
将汉字转换成字符格式,
int i = (short)(array[0]-'\0') * 256 + ((short)(array[1]-'\0'));
这里有一个迷惑人的地方,其实'\0'的值就是0,这里减掉'\0'可能是为了转换成数字格式,也就是说这个公式可以修改成
int i = array[0] * 256 + array[1];
这样就很清晰了,可以理解成把10进制转换成256进制