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

来源:互联网 发布:js中event属性 编辑:程序博客网 时间:2024/04/30 12:30

以前我用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#语句:

 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


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