java基本數據類型各占字節(jié)為:1、整型byte占用1個字節(jié),short占用2個字節(jié);2、浮點型float占用4個字節(jié),double占用8個字節(jié);3、char型占用2個字節(jié)。
相關學習推薦:java基礎教程
在Java中一共有8種基本數據類型,其中有4種整型,2種浮點類型,1種用于表示Unicode編碼的字符單元的字符類型和1種用于表示真值的boolean類型。
一個字節(jié)等于8個bit,java是跟平臺無關的。
(1)整型:
其中byte、short、int、long都是表示整數的,只不過他們的取值范圍不一樣
-
byte的取值范圍為-128~127,占用1個字節(jié)(-2的7次方到2的7次方-1)
-
short的取值范圍為-32768~32767,占用2個字節(jié)(-2的15次方到2的15次方-1)
-
int的取值范圍為(-2147483648~2147483647),占用4個字節(jié)(-2的31次方到2的31次方-1)
-
long的取值范圍為(-9223372036854774808~9223372036854774807),占用8個字節(jié)(-2的63次方到2的63次方-1)。
可以看到byte和short的取值范圍比較小,而long的取值范圍太大,占用的空間多,基本上int可以滿足我們的日常的計算了,而且int也是使用的最多的整型類型了。
在通常情況下,如果JAVA中出現了一個整數數字比如35,那么這個數字就是int型的,如果我們希望它是byte型的,可以在數據后加上大寫的 B:35B,表示它是byte型的。
同樣的35S表示short型,35L表示long型的,表示int我們可以什么都不用加,但是如果要表示long型的,就一定要在數據后面加“L”。
(2)浮點型:
-
float和double是表示浮點型的數據類型,他們之間的區(qū)別在于他們的精確度不同
-
float 3.402823e+38 ~ 1.401298e-45(e+38表示是乘以10的38次方,同樣,e-45表示乘以10的負45次方)占用4個字節(jié)
-
double 1.797693e+308~ 4.9000000e-324 占用8個字節(jié)
double型比float型存儲范圍更大,精度更高,所以通常的浮點型的數據在不聲明的情況下都是double型的,如果要表示一個數據是float型的,可以在數據后面加上“F”。
浮點型的數據是不能完全精確的,所以有的時候在計算的時候可能會在小數點最后幾位出現浮動,這是正常的。
(3)boolean型(布爾型):
這個類型只有兩個值,true和false(真和非真)
-
boolean t = true;
-
boolean f = false;
(4)char型(文本型) :
用于存放字符的數據類型,占用2個字節(jié),采用unicode編碼,它的前128字節(jié)編碼與ASCII兼容
字符的存儲范圍在u0000~uFFFF,在定義字符型的數據時候要注意加' ',比如 '1'表示字符'1'而不是數值1,
char c = ' 1 ';
我們試著輸出c看看,System.out.println(c);結果就是1,而如果我們這樣輸出呢System.out.println(c+0);
結果卻變成了49。
擴展資料
基本類型之間的轉換
將一種類型的值賦值給另一種類型是很常見的。在Java中,boolean 類型與其他7中類型的數據都不能進行轉換,這一點很明確。
但對于其他7種數據類型,它們之間都可以進行轉換,只是可能會存在精度損失或其他一些變化。
轉換分為自動轉換和強制轉換:
-
自動轉換(隱式):無需任何操作。
-
強制轉換(顯式):需使用轉換操作符(type)。
將6種數據類型按下面順序排列一下:
double > float > long > int > short > byte
如果從小轉換到大,那么可以直接轉換,而從大到小,或char 和其他6種數據類型轉換,則必須使用強制轉換。
想了解