在VB中,用ASC函数计算汉字的机内码的问题。

前端之家收集整理的这篇文章主要介绍了在VB中,用ASC函数计算汉字的机内码的问题。前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
在"机内码"的百科一文中

http://baike.baidu.com/link?url=zwf0xM7Jb6f_HUsTcsly-HgJJuXbMMYv0o0BPioQx0igQ1B4uCc7ia49nai2WOwpEdltctP2a90wGtixpMD70a
有一段话如下:由上面我们知道,“保”字的国标码为3123H,前字节为00110001B,后字节为00100011B,
高位改1为10110001B和10100011B即为B1A3H,因此,“保”字的机内码就是B1A3H。
也就是说汉字"保"的2进制为1011000110100011(采用GB2312编码方式),通过我的计算,
这个2进制”1011000110100011“若转为无符号的10进制则为45475,若转为有符号的10进制则为-12707,但通过

asc("保")却得到的是-20061,为什么我计算的不是-20061?这个-20061是不是"保"的机内码的2进制对应的10进制?

----------------------------------------------------

我知道问题的原因啦。
负整数在计算机中是以补码形式储存的,补码是怎么样表示的呢,这里还要引入另一个概念——反码,所谓反码就是把负数的原码(负数的原码和和它的绝对值所对应的原码相同,简单的说就是绝对值相同的数原码相同)各个位按位取反,是1就换成0,是0就换成1,如-1的原码是00000001,和1的原码相同,那么-1的反码就是11111110,而补码就是在反码的基础上加1,即-1的补码是11111110+1=11111111,

所以对于”保“的2进制”1011000110100011“,如果想计算出对应的10进制,要先求出

"1011000110100011"的原码,由于”1011000110100011“加1得到的补码,那么我们再减1就是得到反码”1011000110100010",”1011000110100010"的原码是"1100111001011101",
"1100111001011101"的有符号的10进制=-((2的14次方)+(2的11次方)+(2的10次方)+(2的9次方)+(2的6次方)+(2的3次方)+(2的2次方)+(2的0次方))=-20061
搞定!!!

原文链接:https://www.f2er.com/vb/258228.html

猜你在找的VB相关文章