short(16位)转换成字符与char(16位)表现形式上的区别

解决方案 »

  1.   

    从二进制上来说,没有区别只是从表面含义上来说有区别,char的值>=0,最高位不为符号位
    而short是有负数的
      

  2.   

    我是新手....你是在说二进制吗,“char的值>=0,最高位不为符号位
     而short是有负数的 ”能透彻一点的给我解释吗,谢谢
      

  3.   

    char是16位无符号数,所以范围是0 to 2^16 - 1 (0 to 65535)
    short是16位带符号数,范围是-2^15 to 2^15 - 1 (−32768 to 32767)
      

  4.   

    你要透彻解释:无符号数  无符号数是针对二进制来讲的,无符号数的表数范围是非负数。
      全部二进制均代表数值,没有符号位。即第一个"0"或"1"不表示正负。
      无符号数与有符号数相对
      C支持所有整形数据类型的有符号数和无符号数运算。尽管C标准并没有指定某种有符号数的表示,但是几乎所有的机器都使用二进制补码。通常,大多数数字默认都使有符号的,C也允许无符号数和有符号数之间的转换,转换原则是基本的位表示保持不变。因此在一台二进制补码机器上,当从无符号数转换为有符号数时,效果就是应用U2Tw,而从有符号转换为无符号数时,就是应用函数T2Uw,其中w表示数据类型的位数。
      T2Uw(x) = (x<0)?(x+2w) :x;U2Rw(x) = (x<2w-1)?x:(x-2w);
      当执行一个运算时,如果它的一个运算数是有符号的而另一个是无符号的,那么C会隐含地将有符号参数强制转换为无符号数,并假设这两个数都是非负的,来执行这个运算。
      

  5.   

    有符号数有符号数的实例  有符号数是针对二进制来讲的。
      用最高位作为符号位,“0”代表“+”,“1”代表“-”;其余数位用作数值位,代表数值。
      有符号数的表示:计算机中的数据用二进制表示,数的符号也只能用0/1表示。一般用最高有效位(MBS)来表示数的符号,正数用0表示,负数用1表示。
      有符号数的编码方式,常用的是补码,另外还有原码和反码等。用不同二进制编码方式表示有符号数时,所得到的机器数可能不一样,但是真值应该是相同的。