1. 程式人生 > 其它 >基本資料型別-java學習日記

基本資料型別-java學習日記

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);//a
8.布林型別: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;