国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

6. Java 中的基本數據類型 【連載 6】

Kerr1Gan / 1045人閱讀

摘要:字符串和基本數據類型也能通過進行拼接操作,比如字符串的內容為。即基本類型和字符串類型相加時,基本類型會自動轉換為其字符串表示,在這個例子中相當于回顧包裝類這一小節(jié)的代碼類型的最大值就是將字符串和數據類型的拼接。

數據類型定義了變量可以采用的值,例如,定義變量為 int 類型,則只能取整數值。

在 Java 中有兩類數據類型:

1)原始數據類型

2)非原始數據類型 - 數組和字符串是非原始數據類型,將在以后的教程中討論它們。

這次我們將討論Java中的原始數據類型和字符。

Java 變量必須先指定它的數據類型(變量聲明),然后才能使用。

int num;
像這種變量數據類型在編譯時已知,則這種語言稱為靜態(tài)類型的。
1. 基本數據類型

在Java中,我們有八種基本數據類型:

1)boolean:布爾類型

2)char:字符類型

3)byte:字節(jié)類型

4)short:短類型

5)int:整數類型

6)long:長類型

7)float:浮點類型

8)double:雙精度類型

byteshortintlong 類型用于存儲整數類型數據。

floatdouble 用于存儲分數或者小數類型數據,也可用于存儲整數值。

char用于存儲字符(字母)類型數據。

boolean類型存儲 truefalse,用于邏輯判斷。

3. 常用到的數據類型

1)用于存儲數值常用到的數據類型有intlongdoubleint類型占用內存空間較小,程序運行速度快,double類型占用內存空間較大,程序運行速度相對慢。

2)用于存儲文本的常用數據類型String(非原始數據類型)和char

3)用于決策的 boolean數據類型比較常用

1.1 byte 數據類型

可以保存在-128到127之間的整數。主要用于節(jié)省內存。

默認大小:1個字節(jié)

class ByteExample {
    public static void main(String[] args) {
        byte num;
          System.out.println("存儲最大值:" + Byte.MAX_VALUE);
        System.out.println("存儲最小值:" + Byte.MIN_VALUE);
        System.out.println("默認存儲字節(jié):" + Byte.BYTES);
        num = 113;
        System.out.println(num);
          //num = 160;//編譯會拋出錯誤:不兼容的類型: 從int轉換到byte可能會有損失num = 160;
    }
}

輸出:

存儲最大值:127
存儲最小值:-128
默認存儲字節(jié):1
113
如果 num 的值超出范圍會在編譯時候拋出錯誤:不兼容的類型: 從int轉換到byte可能會有損失
1.2. short 類型數據

它的存儲數值范圍是 -32,768 到 32767。

數據類型默認大小:2個字節(jié)。

class ShortExample {
    public static void main(String[] args) {
        short num;
        System.out.println("存儲最大值:" + Short.MAX_VALUE);
        System.out.println("存儲最小值:" + Short.MIN_VALUE);
        System.out.println("默認存儲字節(jié):" + Short.BYTES);
        num = 150;
        System.out.println(num);
    }
}

輸出:

存儲最大值:32767
存儲最小值:-32768
默認存儲字節(jié):2
150
1.3. int 數據類型

存儲數值范圍:-2147483648 到 2147483647

默認大小:4 字節(jié)

class IntExample {
    public static void main(String[] args) {
        int num;
        System.out.println("存儲最大值:" + Integer.MAX_VALUE);
        System.out.println("存儲最小值:" + Integer.MIN_VALUE);
        System.out.println("默認存儲字節(jié):" + Integer.BYTES);
        num = 1500;
        System.out.println(num);
          num = -1500;
        System.out.println(num);
    }
}

輸出:

存儲最大值:2147483647
存儲最小值:-2147483648
默認存儲字節(jié):4
1500
-1500
1.4. long 數據類型

數值存儲范圍:-9223372036854775808 到 9223372036854775807

默認大小:8 字節(jié)

class LongExample {
    public static void main(String[] args) {
        long num;
        System.out.println("存儲最大值:" + Long.MAX_VALUE);
        System.out.println("存儲最小值:" + Long.MIN_VALUE);
        System.out.println("默認存儲字節(jié):" + Long.BYTES);
        num = 150000000000L;
        System.out.println(num);
        num = -150000000000L;
        System.out.println(num);
    }
}
注意:long類型變量賦值時,數值后面要加上字母L或者小寫l

輸出:

存儲最大值:9223372036854775807
存儲最小值:-9223372036854775808
默認存儲字節(jié):8
150000000000
-150000000000

總結:

bytelong 類型變量存儲范圍越來越大,存儲空間(字節(jié)數)越來越大,程序運行速度越來越小。所以編碼過程中根據數值大小選擇合適數據類型變量,可以優(yōu)化程序運行速度。

1.5. double 數據類型

足夠保存15位十進制數字

默認大小:8 字節(jié)

class DoubleExample {
    public static void main(String[] args) {
        System.out.println("存儲最大值:" + Double.MAX_VALUE);
        System.out.println("存儲最小值:" + Double.MIN_VALUE);
        System.out.println("默認存儲字節(jié)" + Double.BYTES);
        double num = -42937737.9d;
    }
}
注意:double 類型變量賦值時,數值后面要加上字母D或者小寫d

輸出:

存儲最大值:1.7976931348623157E308
存儲最小值:4.9E-324
默認存儲字節(jié)8
-4.29377379E7
1.6 float 數據類型

足夠保存6至7位十進制數字

默認大小:4 字節(jié)

class DoubleExample {
    public static void main(String[] args) {
        System.out.println("存儲最大值:" + Double.MAX_VALUE);
        System.out.println("存儲最小值:" + Double.MIN_VALUE);
        System.out.println("默認存儲字節(jié)" + Double.BYTES);
        double num = -42937737.9d;
    }
}
注意:float 類型變量賦值時,數值后面要加上字母F或者小寫f

輸出:

存儲最大值:3.4028235E38
存儲最小值:1.4E-45
默認存儲字節(jié)4
-18.9
1.7. boolean 數據類型

只存儲 truefalse

class BooleanExample {
    public static void main(String[] args) {
        boolean b = true;
        System.out.println(b);
        b = false;
        System.out.println(b);
    }
}

輸出:

true
false
1.8. char 數據類型

只存儲一個字符

默認存儲大小:2 個字節(jié)

class CharExample {
    public static void main(String[] args) {
        char ch = "z";
        System.out.println("默認存儲字節(jié):" + Character.BYTES);
        System.out.println(ch);
        ch = "1";
        System.out.println(ch);
        //ch = "10";//編譯不過,因為char 類型只能存儲一個字符
    }
}

輸出:

默認存儲字節(jié):2
z
1
2. 整數的不同進制

byteshortintlong都可以用十進制、二進制、八進制以及十六進制的方式來表示。當使用常量字面量時,前綴0b表示二進制,0表示八進制,而前綴0x代表十六進制。比如:

int decimal = 174;
int binary = 0b10101110;
int octal = 0256;
int hexa =  0xAE;

為什么174用二進制表示就是10101110呢?

174是由個位數的4、十位數的7和百位數的1構成:

如果使用二進制,則可以表達為:

上面圖片中所有紅色的數字就構成了二進制表示10101110

哪如何將一個十進制數轉換為二進制數呢?

將十進制數不斷除以2,直到等于0,每次除法產生的余數從后往前合并在一起就是對應的二進制表示:

對于八進制和十六進制,原理是類似的。

3. 類型轉換

一個浮點數字面量默認是double類型,如果要定義float類型則要在字面量最后添加f或者F

double a = 1.23;
float b = 1.23F;
float c = 1.23; // 編譯錯誤

以上代碼中,第三行代碼將出現編譯錯誤,因為1.23這個字面量是double類型的,不能將其賦值給float類型。

一個整數字面量默認是int類型,如果要定義長整形(long)則要在字面量最后添加l或者L。但是

int a = 100;
long b = 100000L;
long c = 100000;

第三行代碼long c = 100000;不會有編譯錯誤,雖然字面量100000int類型的,但是當int類型賦值給long類型時,可以自動轉換long類型。

占用內存空間小的類型可以自動轉換為占用空間大的類型,反之則不成立。你把一個變量的想象成一個箱子,更小的箱子里的東西可以放入到更大的箱子中,將更大的箱子里的東西放到更小的箱子則可能裝不下。比如:

b = a;是合法的賦值

a = b;則是非法的賦值,會有編譯錯誤,這其實也是代碼float c = 1.23;會發(fā)生編譯錯誤的原因

如果一定要將b的值(long類型)賦值給a,則要進行強制轉換

a = (int)b;

b變量前的(int)表示將b的值強制轉換為int類型。注意強制類型轉換時,可能導致數據錯誤,比如b的值超過了int類型的表示范圍,此時就會進行數據截斷(丟掉箱子裝不下的東西),我們應該盡量避免這種情況。

基本類型之間的自動轉換關系如下:

4. 包裝類

以上8種基本類型都不是類,Java提供了對應的類,稱之為包裝類。包裝類可以認為是將基本類型轉換成的一個引用類型。

基本類型 包裝類
byte Byte
short Short
int Integer
long Long
float Float
double Double
boolean Boolean
char Character

每種基本類型所占用的內存空間大小,最大值和最小值,可以通過其包裝類來訪問。比如為了我們可以這樣訪問int類型的相關信息:

 System.out.println("int類型的二進制位數:" + Integer.SIZE);  
 System.out.println("int類型的最小值:Integer.MIN_VALUE=" + Integer.MIN_VALUE);  
 System.out.println("int類型的最大值:Integer.MAX_VALUE=" + Integer.MAX_VALUE); 

注意,將一個整數和字符串通過+號拼接起來,整數可以自動轉換為字符串。

Integerint為例,我們可以將兩者進行轉換,例如:

Integer in = new Integer(100); // 將int轉換為包裝類
int m = in.intValue(); // 獲取Integer的int值
String s = “123”;
int n = Integer.parseInt(s); // 將字符串轉換為整數
String s2 = Integer.toString(n); // 將整數轉換為字符串

其它數據類型的操作是類似的,不再一一贅述。

Integer in = new Integer(100);將int轉換為包裝類,本質就是通過new創(chuàng)建包裝類Integer,調用Integer的構造函數并將100這個int類型的數作為參數傳給構造函數。關于構造函數的細節(jié)在后續(xù)教程中講解。

5. 數組

數組(Array)是程序設計語言中必不可少的一種結構,它用來描述一系列相同類型的數據。一個數組一旦創(chuàng)建后,它的長度是固定的。

下面的代碼,定義了一個長度為10的數組,數據的下標編號從0開始,9是最后一個元素。下面是一個Java語言數組的例子:

int[] anArray;
anArray = new int[10];//初始化一個長度為10的整形數組

anArray[0] = 100;//初始化第一個變量
anArray[1] = 200;
anArray[2] = 300;
anArray[3] = 400;
anArray[4] = 500;
anArray[5] = 600;
anArray[6] = 700;
anArray[7] = 800;
anArray[8] = 900;
anArray[9] = 1000;

數組下標和元素的關系如下所示:

這樣初始化數組比較麻煩,下面是另外一種更加便捷的方式:

int[] anArray = { 100, 200, 300, 400, 500, 600, 700, 800, 900, 1000};

這樣會自動創(chuàng)建一個長度為10的int數組。我們通過anArray.length可以得到數組的長度。

6. String 類型數據

一個字符串就是一個字符序列,字符串被廣泛應用于 Java 編程。Java語言將字符串作為String類型的對象進行處理。

String并不是基本的數據類型,是一個類。最常用的創(chuàng)建字符串對象的方法如下:

String str = "abc";

字符串可以通過++=操作符進行拼接,比如:

String str1 = "abc";    
String str2 = str1 + "def";
str1 += "def";

最后str1str2所指向的字符串內容為"abcdef"。

字符串和基本數據類型也能通過+進行拼接操作,比如:

int a = 100;
String str = "a=" + a;

str字符串的內容為"a=100"。即基本類型和字符串類型相加時,基本類型會自動轉換為其字符串表示,在這個例子中相當于:

String str = "a=" + "100";

回顧包裝類這一小節(jié)的代碼:

System.out.println("int類型的最大值:Integer.MAX_VALUE=" + Integer.MAX_VALUE); 

就是將字符串和數據類型的拼接。

String類的實例是一個不可變的對象,意味著對String的操作都會產生一個新的String對象。

例如,String有一個substring()方法

String str = "123456";
str.substring(3); // 從下標3(注意下標從0開始)開始截取一個子字符串
System.out.println(str); // str本身不可變,所以打印出來依然是123456
String str2 = str.substring(3); // 將產生的新對象賦值給一個新的引用變量
System.out.println(str2); // str2的內容為456

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/68241.html

相關文章

  • Java編程思想學習錄(連載之:異常)

    摘要:系列博文目錄編程思想學習錄連載之一切都是對象編程思想學習錄連載之初始化與清理編程思想學習錄連載之內部類編程思想學習錄連載之異常本篇文章將講述關于異常的相關知識注本文首發(fā)于公眾號,可長按或掃描下面的小心心來訂閱基本概念使用異常來提供一致性的錯 showImg(https://segmentfault.com/img/remote/1460000013228854); Thinking ...

    pkhope 評論0 收藏0
  • 9. 程序的控制流-選擇結構 【連載 9】

    摘要:程序執(zhí)行的過程,我們可以把它認為是一個流,實際的業(yè)務需求會根據不同的情況,來控制程序不同的流轉。中對應的結構為控制結構。程序跳轉到語句后面的語句執(zhí)行。 showImg(https://segmentfault.com/img/remote/1460000012984073?w=900&h=500); 程序執(zhí)行的過程,我們可以把它認為是一個流,實際的業(yè)務需求會根據不同的情況,來控制程序不...

    TNFE 評論0 收藏0
  • 8. Java 中的運算符 【連載 8】

    摘要:語言中給我們提供了專門用來操作這些數據的代碼符號,統(tǒng)稱為運算符。運算符的優(yōu)先級運算符優(yōu)先級決定一個表達式里術語的分組。一定的運算符比其他運算符擁有更高的優(yōu)先級。 showImg(https://segmentfault.com/img/remote/1460000012983569?w=900&h=500); 在前面的內容已經學會了如何定義變量和初始化變量。定義變量的目的就是為了操作數...

    Panda 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<