Spring 官宣高危漏洞 大家好,我是棧長。 前幾天爆出來的 Spring 漏洞,剛修複完又來? 今天愚人節來了,這是和大家開玩笑嗎? 不是的,我也是猝不及防!這個玩笑也開的太大了!! 你之前看到的這個漏洞已經是過去式了: 我以為是終點,沒想到只是起點,現在 Spring 又官宣了最新的高危漏洞: ...
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類型的變數 short s = 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;