`
shinfocom
  • 浏览: 1181404 次
文章分类
社区版块
存档分类
最新评论

探讨?C#中如何得到双字节字符的ASCII码 C# asc() 和vb

 
阅读更多

以前我用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#确实麻烦,一大堆不知道的东西,

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

什么asciiencoding,结果得到的是63,解释为不能识别的编码,这倒好,以后只要是中文,全是63,
试了utf8的,unicode,真是不知所云,平常对编码太不熟悉了。

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

<!--/ubbcodetab-->encoding ecode = encoding.getencoding("gb18030");

开始写代码:

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


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

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics