基本資料型別-java學習日記
阿新 • • 發佈:2022-04-01
1.不同進位制的資料組成
二進位制: 由0,1組成。以0b開頭
八進位制: 由0,1,…7組成。以0開頭
十進位制:由0,1,…9組成。整數預設是十進位制
十六進位制: 由0,1,…9,a,b,c,d,e,f(大小寫均可)。以0x開頭
2.資料型別面試題
byte b1=3,b2=4,b;
b=b1+b2;
b=3+4;
哪句是編譯失敗的呢?為什麼呢?
第二句編譯失敗,b1、b2在運算時資料型別會提升到int型別,運算之後的結果也是int,不能直接賦值給btye型別變數,必須強轉
第三句常量在運算的時候,運算結果會根據要賦值的變數型別自動切換(前提是資料在有效範圍內)
3.位運算子面試題
請用最有效率的方式寫出計算2乘以8的結果 2>>3
請自己實現兩個整數變數的交換 a=a^b b=a^b a=a^b
4.變數
概念:
記憶體中的一個儲存區域,變數的值可以在同一類型範圍內不斷變化,變數是程式中最基本的儲存單元。(包含變數型別、變數名和儲存的值)
作用:
用於在記憶體中儲存資料
注意事項:
java中的變數必須先聲明後使用。
使用變數名來訪問這塊區域的資料
變數的作用域:其定義所在的一對{ }內
變數只有在其作用域內才有效
同一個作用域內,不能定義重名的變數
分類-按資料型別
補充:變數的分類,按宣告的位置不同
在方法體外,類體內宣告的變數稱為成員變數
在方法體內部宣告的變數稱為區域性變數
5.整數型別:byte、short、int、long
java的整型常量預設為 int 型,宣告long型常量須後加‘l’或‘L’
java程式中變數通常宣告為int型,除非不足以表示較大的數,才使用long
bit: 計算機中的最小儲存單位。byte:計算機中基本儲存單元。
//定義變數的語句格式 //資料型別 變數名 = 初始化值; //定義一個byte型別的變數 byte b = 10; System.out.println(b); System.out.println(10); //定義一個short型別的變數 shorts = 100; System.out.println(s); //定義一個int型別的變數 int i = 1000; System.out.println(i); //數值超過了int型別可接收範圍,要使用更大的資料型別去接收 // int i1 = 100000000000; long l = 100000000000L; System.out.println(l); long l2 = 100L; System.out.println(l2);
6.浮點型別:float、double float:單精度,尾數可以精確到7位有效數字。很多情況下,精度很難滿足需求。 double:雙精度,精度是float的兩倍。通常採用此型別。 Java 的浮點型常量預設為double型,宣告float型常量,須後加‘f’或‘F’。
//定義一個float型別的變數 float f = 12.34F; System.out.println(f); //定義一個double型別的資料 double d = 23.45; System.out.println(d);
7.字元型別:char char 型資料用來表示通常意義上“字元”(2位元組) Java中的所有字元都使用Unicode編碼,故一個字元可以儲存一個字母,一個漢字,或其他書面語的一個字元。 字元變數的三種表現形式: 字元常量用單引號(‘ ’)括起來的單個字元。例如:char c1 = 'a'; char c2 = '中'; char c3 = '9'; Java中還允許使用轉義字元‘\’來將其後的字元轉變為特殊字元型常量。 例如:char c3 = ‘\n’; // '\n'表示換行符 直接使用 Unicode 值來表示字元型常量:‘\uXXXX’。其中,XXXX代表 一個十六進位制整數。如:\u000a 表示 \n。 char型別是可以進行運算的。因為它都對應有Unicode碼。
//定義一個字元型別的變數 char c = 'a'; System.out.println(c);//a8.布林型別:boolean boolean 型別用來判斷邏輯條件,一般用於程式流程控制: if條件控制語句; while迴圈控制語句; do-while迴圈控制語句; for迴圈控制語句; boolean型別資料只允許取值true和false,無null
//定義一個布林型別的變數 boolean b2 = true; boolean b3 = false; System.out.println(b2);//true System.out.println(b3);//false
9.基本資料型別轉換 自動型別轉換:容量小的型別自動轉換為容量大的資料型別。資料型別按容 量大小排序為: 有多種型別的資料混合運算時,系統首先自動將所有資料轉換成容量最大的那種資料型別,然後再進行計算。 byte,short,char之間不會相互轉換,他們三者在計算時首先轉換為int型別。 boolean型別不能與其它資料型別運算。 當把任何基本資料型別的值和字串(String)進行連線運算時(+),基本資料類 型的值將自動轉化為字串(String)型別。
//需求:求出3+4的值 System.out.println(3 + 4);//直接列印3+4的結果 --------------- // 用變數的形式去做 int a = 3; int b = 4; int c = a + b; System.out.println(c);//7 ---------------- // 定義一個byte型別的資料,一個int型別的資料,做加法 byte a = 3; int b = 4; int c = a + b; System.out.println(c);//7 byte a = 3; int b = 4; byte c = (byte) (a + b);//強轉成byte資料,不建議,可能會導致資料丟失 System.out.println(c);//7 ------------------- 定義一個int型別資料,一個double型別資料,做減法 int a2 = 100; double d2 = 12.34; double d3 = a2 - d2; System.out.println(d3);//87.66 int a3 = (int)(a2-d2);//強轉int型別資料,資料丟失 System.out.println(a3);//87
思考題
public class DataTypeDemo5 { public static void main(String[] args) { //思考題1:請問下面程式碼有沒有問題,如果有,怎麼改? //小數預設就是double型別 double d = 12.345; //float型別所佔大小比double要小,需要強制型別轉換,可能會損失精度 float f = (float) d; //思考題2:下面兩個程式碼有什麼區別呢? // f1其實是由double型別的資料做強制型別轉換得來的,可能會損失精度 float f1 = (float)12.345; //f2接收的資料實際上本身就是一個float型別的資料,不存在會損失精度的問題 float f2 = 12.345f;