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

王朝c#·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

以前我用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() );

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

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

/// <summary>

/// 是否为双字节字符。

/// </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码:

/// <summary>

/// 得到字符的ASCII码

/// </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

我不知在做什么,为了这个简单的功能,就好象到黄山去旅游,结果坐船先到美洲,再到欧洲,再到三峡,再到黄山。

就因为,我找不到直接去黄山的专车,如果谁知道了,来告诉一下。

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

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航