java byte的无符号表示

 1. 将一个整数转换为字节(如将整数255转换为字节)

byte b1 = (byte)255

输出: b1 = -1

 

2. 将字节转换为无符号数(如将-1转换为无符号数)

byte b1 = -1

int  n = b1 & 0xFF

输出:n=255

 

3. 若转换成无符号数中涉及到移位操作,还有些需要注意的地方。如:

例1

byte b2 = -1;

(b2 & 0xFF)  << 8  或  (b2 << 8) & 0xFFFF  (注:FF后无'L")

输出:65280

 

例2

byte b2 = -1;

(b2 & 0xFFL)  << 24  或  (b2 << 24) & 0xFFFFFFFFL   (注:FF后有'L")

输出:4278190080

 

由于例2中左移了24位,使得b2所表示的无符号数超过了Int所能表示的最大值Integer.MAX_VALUE(2147483647),

因此转换成无符号数时需要用long型来表示。这也就解释了为什么例2中"FF"后需要添加"L"。

 

[java]   view plain copy
 
  1. byte a = (byte)234;  
  2. System.out.println(a);  


 

上面的代码,结果是-22,因为java中byte是有符号的,byte范围是-128~127。

如果想输出234,该怎么做呢,首先想到的是将a 赋给大一点的类型,如下:

 

[java]   view plain copy
 
  1. byte a = (byte)234;   
  2. int i = a;  
  3. System.out.println(a);  

执行后,还是-22,因为int也是有符号的,所以a赋给i时,a的符号位在i中成为了i的符号位。

 

正确方法应该是:

 

[java]   view plain copy
 
  1. byte a = (byte)234;  
  2. int i = a;    
  3. i = a&0xff;  
  4. System.out.println(i);  

原因是:

0xff是int,占4个字节,a是byte,占1个字节,进行&操作的细节如下:

    00000000 00000000 00000000 11101010    (a)

&

   00000000 00000000 00000000 11111111    (i)

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

= 00000000 00000000 00000000 11101010

结果是int,但是符号位是0,说明是正数,最后就是正整数234.

其实这个方法在C语言中也可以获取有符号char的无符号值,但是C语言中可以直接使用unsigned来转换就可以,比这个方便。

 

http://blog.csdn.net/androiddeveloper_lee/article/details/6619414

http://blog.sina.com.cn/s/blog_7a35101201012n0b.html

你可能感兴趣的:(Java)