Java基礎-Java基本數據類型
1 前言
變量就是申請內存來存儲值。也就是說,當創(chuàng)建變量的時候,需要在內存中申請空間。
內存管理系統(tǒng)根據變量的類型為變量分配存儲空間,分配的空間只能用來儲存該類型數據。
因此,通過定義不同類型的變量,可以在內存中儲存整數、小數或者字符。
Java支持八種基本數據類型,包括一種布爾類型、一種字符類型、一種數值型,包括四種整數類型和兩種浮點數類型。
2 布爾類型
boolean
數據類型表示一位的信息;- 只有兩個取值:
true
和false
; - 這種類型只作為一種標志來記錄
true/false
情況; - 默認值是 false;
- 例子:
boolean b = true2
3 字符類型
- char 類型是一個單一的 16 位 Unicode 字符;
- 最小值是 \u0000(十進制等效值為 0);
- 最大值是 \uffff(即為 65535);
- char 數據類型可以儲存任何字符;
- 例子:
? char c = 'A';
4 值類型
4.1 byte
- byte 數據類型是8位、有符號的,以二進制補碼表示的整數;
- 最小值是 -128(-2^7);
- 最大值是 127(2^7-1);
- 默認值是 0;
- byte 類型用在大型數組中節(jié)約空間,主要代替整數,因為 byte 變量占用的空間只有 int 類型的四分之一;
- 例子:
? byte b = 100;
4.2 short
- short 數據類型是 16 位、有符號的以二進制補碼表示的整數
- 最小值是 -32768(-2^15);
- 最大值是 32767(2^15 - 1);
- Short 數據類型也可以像 byte 那樣節(jié)省空間。一個short變量是int型變量所占空間的二分之一;
- 默認值是 0;
- 例子:
? short short s = -10000;
4.3 int
int
數據類型是32位、有符號的以二進制補碼表示的整數;- 最小值是 -2,147,483,648(-2^31);
- 最大值是 2,147,483,647(2^31 - 1);
- 一般地整型變量默認為 int 類型;
- 默認值是 0 ;
- 例子:
? int a = 100000;
4.4 long
long
數據類型是 64 位、有符號的以二進制補碼表示的整數;- 最小值是 -9,223,372,036,854,775,808(-2^63);
- 最大值是 9,223,372,036,854,775,807(2^63 -1);
- 這種類型主要使用在需要比較大整數的系統(tǒng)上;
- 默認值是 0L;
- 例子:
?long l = 100000L;
"L"理論上不分大小寫,但是若寫成"l"容易與數字"1"混淆,不容易分辯。所以最好大寫。
4.5 float
float
數據類型是單精度、32位、符合IEEE 754標準的浮點數;float
在儲存大型浮點數組的時候可節(jié)省內存空間;- 默認值是 0.0f;
- 浮點數不能用來表示精確的值,如貨幣;
- 例子:
? float f1 = 234.5f;
4.6 double
double
數據類型是雙精度、64 位、符合 IEEE 754 標準的浮點數;- 浮點數的默認類型為 double 類型;
- double類型同樣不能表示精確的值,如貨幣;
- 默認值是 0.0d;
- 例子:
? double d5 = 12.9867;?
5 碼農來洞見
5.1 類型轉換
Java允許整數和浮點數之間互相轉換。并且,由于每個字符都對應Unicode編碼中的一個數字,所以char
與整數和浮點數之間也可以相互轉換。事實上,在Java中,boolean類型是唯一一種不能跟其他基本類型相互轉換的基本類型。
自動類型轉換:
也叫隱式類型轉換,其實就是小范圍的數據類型向大范圍的數據類型轉換(byte ->short(char)->int->long->float->double)
。
強制類型轉換:
也叫顯式類型轉換,是從存儲范圍大的類型到存儲范圍小的類型(double→float→long→int→short(char)→byte)
。強制類型轉換所帶來的結果是可能會丟失精度,如果此數值尚在范圍較小的類型數值范圍內,對于整型變量精度不變,但如果超出范圍較小的類型數值范圍內,很可能出現(xiàn)一些意外情況。
int i = 223; byte b = (byte) i;
上面的例子中輸出值是-23.
為什么結果是-23?需要從最根本的二進制存儲考慮。
233的二進制表示為:24位0 + 11101001,byte型只有8位,于是從高位開始舍棄,截斷后剩下:11101001,由于二進制最高位1表示負數,0表示正數,其相應的負數為-23。
數據類型自動提升:
數值類型在內存中直接存儲其本身的值,對于不同的數值類型,內存中會分配相應的大小去存儲。如:byte類型的變量占用8位,int類型變量占用32位等。相應的,不同的數值類型會有與其存儲空間相匹配的取值范圍。
在Java中,整數類型(byte/short/int/long)
中,對于未聲明數據類型的整型,其默認類型為int型。在浮點類型(float/double
)中,對于未聲明數據類型的浮點型,默認為double型。
5.2 存儲空間
注意事項1:
如果需要一個占位符來存儲數字1000000,那么需要一個int型數,long可以用于存儲更大的數字,讀者可能問,既然long可以包含比byte和int型數更大的數字,為什么不總是使用long呢?這是因為long需要64位,相比byte
或int,這會占用更多的內存空間。因此,為了節(jié)省空間,需要選擇合適的基本類型。
注意事項2:
將一個int型的1000賦給一個byte型的變量a,提示出錯,但是最后一句:將一個int型的3賦給一個byte型的變量c,居然編譯正確,這是為什么呢?
byte b1 = 1000; byte b2 = 3;
原因在于:jvm
在編譯過程中,對于默認為int類型的數值時,當賦給一個比int型數值范圍小的數值類型變量,會進行判斷,如果此int型數值超過數值類型,那么會直接編譯出錯。但是如果此int型數值尚在數值類型范圍內,jvm會自動進行一次隱式類型轉換。
到此這篇關于Java基礎-Java基本數據類型的文章就介紹到這了,更多相關Java基本數據類型內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
SpringBoot與Spring中數據緩存Cache超詳細講解
我們知道內存讀取速度遠大于硬盤讀取速度,當需要重復獲取相同數據時,一次一次的請求數據庫或者遠程服務,導致在數據庫查詢或者遠程方法調用上小號大量的時間,最終導致程序性能降低,這就是數據緩存要解決的問題,學過計算機組成原理或者操作系統(tǒng)的同學們應該比較熟悉2022-10-10