
【學習背景】
相信很多初學Java的小伙伴或者已經入行的小伙伴,都知道Java的資料型別主要分為參考資料型別和基本資料型別,參考資料型別就是平時大家說的萬物皆物件Object,而基本資料型別,則有八種,大家應該都記得(也可能不知道或者記不全了,哈哈哈)
如果你是Java初學者,那么當你去面試Java初級工程師崗位的時候,面試官可能會比較喜歡問這個問題,主要是想考察小伙伴們對基本資料型別了解多少,寫代碼時會不會亂用基本資料型別,給公司的大佬們挖坑,哈哈哈~
本文主要目的是給Java初學者或者想要加深自己對這八種基本資料型別的認識和理解的小伙伴,應屆生秋招進行中了,很多剛畢業的小伙伴,當你再去面試遇到面試官讓你回答【關于Java八種基本資料型別?】這個問題的時候,不要就簡單的回答,Java八種基本資料型別有
byte/short/char/int/float/double/long/boolean…OVER!!
相信學習了本文,你還可以在從這幾個方面去回答,可能會更加分哇~
- 八種基本資料型別的
默認值是多少?- 八種基本資料型別的
取值范圍是多少?- 八種基本資料型別的
占用空間如何?- 八種基本資料型別的
相互轉換?
進入正文~
學習目錄
- 一、八種基本資料型別
- 1.1 位元組型byte
- 1.2 短整型short
- 1.3 字符型char
- 1.4 整型int
- 1.5 單精度浮點型float
- 1.6 雙精度型double
- 1.7 長整型long
- 1.8 布爾型boolean
- 二、基本資料型別轉換
- 2.1 自動轉換型別
- 2.2 強制轉換型別
- 三、面試總結
- 八種型別?
- 默認值?
- 占用空間?
- 取值范圍?
- 型別轉換?
一、八種基本資料型別
1.1 位元組型byte
位元組(byte)是計算機的基本單位,但不是最小的單位,最小的單位是位(bit)
1 byte = 8bit 即一個位元組占用8位二進制~
- 默認值: 0;
- 數值范圍:
(-2^7) ~ (2^7-1) 即 -128 ~ 127;- 占用空間:
1 byte= 8bit即一位元組占用8位二進制;- 注意事項:byte在大容量陣列中使用時非常節省空間,只占用int型別的四分之一;
- 代碼例子:byte b1 = -127,byte b2 = 128;
1.2 短整型short
短整型short 是一種比較小的整數~
- 默認值:
0;- 數值范圍:
(-2^15) ~ (2^15 - 1)即 -32768 ~ 32767;- 占用空間:
2 byte= 16bit即兩位元組占用16位二進制;- 注意事項:在大容量陣列中使用相對節省空間,只占int的二分之一;
- 代碼例子:short s1 = -666,short s2 = 666,
1.3 字符型char
char字符型是Java非常獨特的基本資料型別,占用兩個位元組,采用了Unicode(萬國碼)作為字符編碼,可以存盤任何字符
- 默認值:
0(注意這里的0是Unicode值,對應的字符是空字串'');- 數值范圍:
0 ~ 65535對應Unicode碼\u0000 ~ \uffff(常用字符數值,例如空字符’'對應0、'A’對應65、'a’對應97、字符數字’0’對應48);- 占用空間:
2 byte= 16bit即兩個位元組占用16位二進制;- 注意事項:計算機業界為實作跨語言資訊交換提供了兩種比較常用的交換碼,分別是ASCII(美國資訊交換標準代碼,范圍0 ~ 127)和UNICODE(單一碼或萬國碼,范圍 0~ 65535)
- 代碼例子:char c= ‘’;char c1= ‘A’;char c2= ‘a’;char c3= ‘0’;
1.4 整型int
我們平時講的整數,在Java中指的就是int整型
- 默認值: 0;
- 數值范圍:
-2^31 ~ (2^31 - 1)即 -2,147,483,648 ~ 2,147,483,647;- 占用空間:
4 byte(32bit)即兩個位元組占用32位二進制;- 代碼例子:int i1 = -9999999, int i2 = 9999999,
1.5 單精度浮點型float
單精度浮點型float是Java中的一種浮點型,數值后面帶F或f~
- 默認值:
0.0F(或0.0f);- 數值范圍:
-2^128 ~ 2^127精度范圍:7~8位有效數字(不用刻意記)- 占用空間:
4 byte= 32bit即兩個位元組占用32位二進制;- 注意事項:
(1)在大容量浮點陣列中使用比較節省空間,只占double型別的二分之一
(2)因為float浮點型是有精度的,不能用來表示精確的值,因此實際開發涉及到金錢貨幣的,不能用float,一般使用BigDecimal,感興趣的話,可以百度了解下;
- 代碼例子:float f1 = 123.45F;或 float f2 = 123.45f;
1.6 雙精度型double
雙精度浮點型double是Java中默認的一種浮點型,數值后面帶D或d或者不帶識別符號的小數~
- 默認值:
0.0D或0.0d或0.0;- 數值范圍:取值范圍:
-2^1024 ~ 2^1023精度范圍:16~17位有效數字(不用刻意記);- 占用空間:
8 byte= 64bit即兩個位元組占用64位二進制;- 代碼例子:double d1=7D;double d2=7d;double d3=7.0;
- 注意事項:同樣double浮點型是有精度的,不能用來表示精確的值,因此實際開發涉及到金錢貨幣的,不能用float,一般使用BigDecimal,感興趣的話,可以百度了解下;
1.7 長整型long
長整型long,顧名思義,一般用來存盤比較大的整數值~
- 默認值:
0L(或0l,不過不建議使用小寫字母l,容易與數字1混淆);- 數值范圍:
-2^63 ~ (2^63 -1)即 -9,223,372,036,854,775,808 ~ 9,223,372,036,854,775,807;- 占用空間:
8 byte= 64bit即兩個位元組占用64位二進制;- 代碼例子:long l1 = -9999999999999L,Long l2 = 9999999999999L;
1.8 布爾型boolean
布爾型boolean與其他7種基本資料型別不同,只有true/false兩種值,主要用來做判斷條件的~
- 默認值:
false;- 數值范圍:
true/false;- 占用空間:
1bit 或 4bit;- 代碼例子:boolean b1 = true,boolean b2 = false;
- 注意事項:關于boolean型別的true/false占用1bit還是4bit,業界并沒有給出精確的定義,因為boolean編譯后其實使用了int代替,而true用1表示,false用0表示,《Java虛擬機規范》中也給出了boolean占用4個位元組、boolean陣列占用1個位元組的定義;
二、基本資料型別轉換
經過前面的學習,我們知道除了boolean型別,其他7種基本資料型別占用的位數空間由小到大為:
byte(8位) < short(16位) = char(16位) < int(32位) = float(32位) < double(64位) = long(64位)
2.1 自動轉換型別
當兩種基本資料型別做運算時,最終的結果自動提升為位數空間比較大的那個型別
例如:
double d1 = 1.1;
int i1 = 1;
double value = d1 + i1;
你不能:
double d1 = 1.1;
int i1 = 1;
int value = d1 + i1;

需要注意的是,char/short、int/float及double/long兩兩位空間是一樣大小的,并不是能全部實作自動型別轉換,不過一般現在的IDE等開發工具,都會自動編譯報錯,如有需要使用強制轉換型別即可,這個問題不大~

2.2 強制轉換型別
當兩種基本資料型別做運算時,最終的結果會自動提升為位數空間比較大的那個型別,如果我們想要讓結果是位數空間比較小的那個型別,就需要進行強制轉換~
例如,前面講到的直接用int接收double數值結果的錯誤例子:
double d1 = 1.1;
int i1 = 1;
int value = d1 + i1;
這種情況,就可以使用強制轉換符(型別)來實作:
double d1 = 1.1;
int i1 = 1;
int value = (int)(d1 + i1);
不過細心的同學,強制轉換型別,可能會導致精度丟失,比如本來是double型別的結果是2.1,強制轉換為int型別后得到value變成2了,精度丟失了
三、面試總結
八種型別?
byte/short/char/int/float/double/long/boolean
默認值?
byte(0) /short(0) /char(
0)/int(0)/long(0L)/float(0.0f)/double(0.0d)/boolean(false)
PS:這里需要注意的是char字符型的默認值是0,是一個空字符'',Unicode碼對應'\u0000',順便提一下參考資料型別的默認值是null值~
占用空間?
byte(1位元組8位)/short(2位元組16位) /char(2位元組16位) /int(4位元組32位) /float(4位元組32位) /double(8位元組64位) /long(8位元組64位)/boolean(1位元組或4位元組)
取值范圍?
關于取值范圍,我發現除了字符型char和float、double比較特殊之外,其他一般都是套用公式
-2^(位數-1)~( 2^(位數-1) -1)計算出來的
| 型別 | 取值范圍 |
|---|---|
| char | 0 ~ (-2^16 -1) 即 0 ~ 65535 |
| byte | -2^7 ~ (-2^7 -1) 即 -128 ~ 127 |
| short | -2^15 ~ (-2^15 -1) 即 -32768 ~ 32767 |
| int | -2^31 ~ -2^31 -1 即 -2147483648 ~ 2147483647 |
| float | 取值范圍:-2^128 ~ 2^127 精度范圍:7~8位有效數字(不用刻意記) |
| double | 取值范圍:-2^1024 ~ 2^1023 精度范圍:16~17位有效數字(不用刻意記) |
| long | -2^63 ~ -2^63 -1 即 -9223372036854775808 ~ 9223372036854775807 |
| boolean | true/false |
型別轉換?
當兩種基本資料型別做運算時,最終結果會自動轉為位數空間大的那個型別,如果想要最終結果為位數空間小的型別,可以通過強制轉換符
(型別)指定括號里面的型別來實作,
原創不易,覺得有用的小伙伴來個三連(點贊+收藏+評論 )+關注支持一下,非常感謝~


轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/300233.html
標籤:java
上一篇:cgb2107-day15
