探讨?C#中如何得到双字节字符的ASCII码

以前我用VB,很快得出了这个想要的结果:

Dim ascStr as string = ASC(TextBox.Text(0))

可是我用C#了,对这个看似简单的,也费尽了脑。

string ascStr = (int)textBox1.Text[0];

能对付abcd.....及+_(),但对“我,你、他”就没办法了,不信你试试:

**比较VB的ASC——C#的int值:

** VB(ASC)的我:-12590
C#(INT)的我:25105,减( 2^16=65536 )为:-40431

哭了......

我看书,找不到,看帮助。但C#确实麻烦,一大堆不知道的东西,
什么ASCIIEncoding,结果得到的是63,解释为不能识别的编码, 这倒好,以后只要是中文,全是63,
试了UTF8的,Unicode,真是不知所云,平常对编码太不熟悉了。

最后用Encoding类,可是还是得不到结果。找啊找......,结果发现中文支持,要支持中文,它的编码名称为GB18030,代码页54936,
用C#语句:

**Encoding ecode = Encoding.GetEncoding("GB18030");
**
开始写代码:

Encoding ecode = Encoding.GetEncoding("GB18030");
Byte[] codeBytes = ecode.GetBytes(chr.ToString());
MessageBox.Show( codeBytes[0].ToString() );

结果得到了个百位数的值,又不行。

忽然想到了中文字都是双字节的,就用一个函数判断一下,该字符是否为双字节

///

1<summary>   
2///  是否为双字节字符。    
3/// </summary>

public static bool IsTwoBytesChar( char chr)
{
string str =chr.ToString();
// 使用中文支持编码
Encoding ecode = Encoding.GetEncoding("GB18030");
if (ecode.GetByteCount(str) == 2)
{
return true;
}
else
{
return false;
}
}

好了,就来得到这个ASCII码:

///

1<summary>   
2///  得到字符的ASCII码    
3/// </summary>

public static int ASCII( char chr)
{
Encoding ecode = Encoding.GetEncoding("GB18030");
Byte[] codeBytes = ecode.GetBytes(chr.ToString());
if ( IsTwoBytesChar(chr) )
{
// 双字节码为高位乘256,再加低位
// 该为无符号码,再减65536
return ( int )codeBytes[0] * 256 + ( int )codeBytes[1] - 65536;
}
else
{
return ( int )codeBytes[0];
}
}

测试:输入“我”
终于得到了想要的:-12590

我不知在做什么,为了这个简单的功能,就好象到黄山去旅游,结果坐船先到美洲,再到欧洲,再到三峡,再到黄山。
就因为,我找不到直接去黄山的专车 ,如果谁知道了,来告诉一下。

不过没关系,我风景看够了。

Published At
Categories with Web编程
Tagged with
comments powered by Disqus