程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> JAVA綜合教程 >> 基本數據類型,java基本數據類型

基本數據類型,java基本數據類型

編輯:JAVA綜合教程

基本數據類型,java基本數據類型


byte tt=(byte)130  等於 -126 。 byte 占一個字節,8bit 。第一位是符號位,0 表示正數,1 表示負數。因此byte 的取值范圍 [-128, 127] 。

130的二進制是00000000000000000000000010000010,截取成byte類型只保留後8位,也就是10000010,第1位是符號位0代表正數、1代表負數,這裡第一位是1也就是負數,計算機存儲的負數是補碼,必須將其他位取反再加1,取反加1後這個為-1111110,這個二進制數轉換為整數是-126 。

byte a= (byte) 0x00000111;   十六進制 16*16 + 16 + 1 = 256 + 17 =  0000001  00010001 。截取後8位,則 a = 17 。

byte c = (byte)0xFF;  十六進制 15*16 + 15 = 255 = 11111111 , 最前面1表示負數, 存儲的是 補碼,後面7位取反 加 1 等於 1 , 則 c = -1 。   System.out.println(c);  輸入 -1 。

八進制必須以 0 開頭, 十進制不能以0開頭(0除外)。

byte a= 00000111;  八進制 64 + 8 + 1 , 則 a = 73 。

byte a= (byte)00001111; 八進制 8*8*8 + 64 + 8 + 1 = 00000010 01001001 , 轉換成byte,取後8位,則 a = 73 。   byte a= 00001111 ,會報錯超出范圍[-128,127] 。

 

byte占 8位。 short 占 16位,取值范圍 [-32768, 32767]

short s1 = 1; s1 = s1 + 1; 會報錯,因為1是int類型,計算結果是 int類型,需要強制轉換成short類型,寫成  s1 = (short)(s1 + 1) ;  或者 s1 += 1; 此種寫法含有隱式的強制類型轉換。 相當於(short)(s1 + 1)  

 

int類型在內存中占32位,4個字節。取值范圍 [-2147483648, 2147483647]。

2^31 = 2147483648

 

long型如果賦值超出int型的范圍,則需要在數字後加上L或l 。表示該值是長整型。

long n = 2147483650L + 4; 則 n 值是 2147483654 。 

long m = (long)(2147483647 + 4);  計算過程:2147483647 存儲是: 01111111 11111111 11111111 11111111 加上 00000000 00000000 00000000 00000100 等於 10000000 00000000 00000000 00000011 。

前面的1 表示負數。負數存儲的是補碼,將其他位取反加 1 。 源碼是 11111111 11111111 11111111 11111101 。 則 m 等於 -(2^32-1-2)= -2147483645 。

 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved