麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

第2章 包裝類

2019-11-14 15:10:12
字體:
來源:轉載
供稿:網友

我們知道java是面向對象的語言,其精髓之一是可以使用多態性,提高程序的靈活度。

但是java中有8個基本類 型:byte,short,int,long,float,double,char,boolean。它們是以值的形式存在于內存中,而不是對象。

它們不 是Object的子類,不能參與面向對象的開發。在java1.5版本以前以下的代碼是不能通過的.

 

package com.souvc.api;public class Test {    public static void main(String[] args) {        String str = "hello";        doSome(str);// 可以,因為String是Object的子類        int i = 1;        // 程序編譯不通過,原因在于int不是Object的子類,不能使用多態性。        doSome(i);    }    public static void doSome(Object o) {        // ....    }}

 

問題出現的原因就是基本類型int沒有繼承關系,它不是Object的子類。所以,若想讓基本類型以對象的形式存在,我們就需要定義一個類 Integer,然后用其實例來描述一個基本類型int。

這樣的好處在于,我們使用對象來描述基本類型數據,而類又是繼承自Object的。從而可以讓基 本類型參與面向對象的開發。好在,像Integer這樣的類不需要我們定義,因為java已經提供了8中基本類型對應的包裝類。

注:java1.5版本后出現了自動拆裝箱特性,上述代碼可以正常編譯通過。自動拆裝箱我們后面會詳細描述。

對于8個基本類型,java提供了他們相應的包裝類:

 

基本類型 包裝類

 

byte java.lang.Byte

short java.lang.Short

int java.lang.Integer

long java.lang.Long

float java.lang.Float

double java.lang.Double

char java.lang.Character

boolean java.lang.Boolean

 

其中除了Character與Boolean的父類是Object之外,其余的都是繼承自:java.lang.Number

 

Number是一個抽象類。本身不能實例化。Number 的子類必須提供將表示的數值轉換為 byte、double、float、int、long 和 short 的方法

比如:

abstract double doubleValue() 以double形式返回指定的數值

abstract int intValue() 以int形式返回指定的數值

abstract float floatValue() 以float形式返回指定的數值

剩下的抽象方法請參閱API文檔:java.lang.Number 。

 

 

現在我們來學習一下如何在基本類型與包裝類之間相互轉換。

當我們需要將基本類型轉換為包裝類時,我們可以調用包裝類的一個靜態方法valueOf():

 

Integer i = Integer.valueOf(1);Double d = Double.valueOf(1.1);

 

當我們需要將包裝類轉換為基本類型時,我們可以使用包裝類的方法xxxValue()方法(這里不同的包裝類方法名不完全一致,但都是以Value結尾):

Integer i = new Integer(1);int n = i.intValue();Double d = new Double(1.1);double dn = d.doubleValue();

 

雖然我們可以通過上述的方法在基本類型與包裝類之間相互轉換。但是在實際編寫代碼時相對還是比較麻煩的。java在1.5版本后推出了一個新的特性:自動拆裝箱。

以下代碼在java1.4時編譯不通過,但是在java1.5之后可以:

 int i = new Integer(1);//可以自動將包裝類轉換為基本類型  自動拆箱 Integer in = 1;//可以自動將基本類型轉換為包裝類  自動裝箱

 

那么java是如何實現的自動拆裝箱呢?

事實上JVM不支持該特性,自動拆裝箱只是編譯器在編譯過程中的"預處理"操作。編譯器在看到需要在包裝類與基本類型之間轉換時,會在編譯為字節碼時進行改變:

源代碼中 編譯后的字節碼中

Integer a = 100 => Integer a = Integer.valueOf(100);

Integer b = 200 => Integer b = Integer.valueOf(200);

Integer c = a+b => Integer c = Integer.valueOf (a.intValue( ) + b.intValue( ));

double d = c => double d = c . doubleValue( );

 

 

2.1 Integer類——整數類 34


2.1.1 構造方法——Integer類的構造方法 34
2.1.2 常量——Integer類的常量 34
2.1.3 bitCount方法——獲取二進制補碼中1的數量 34
2.1.4 byteValue方法——獲取byte類型的值 35
2.1.5 compareTo方法——比較整數 35
2.1.6 decode方法——字符串解碼為int類型 35
2.1.7 doubleValue方法——返回double數值 36
2.1.8 equals方法——判斷整數對象相等 36
2.1.9 floatValue方法——獲取float數值 37
2.1.10 getInteger方法——獲取整數的系統屬性值 37
2.1.11 hashCode方法——生成整數的哈希碼 39
2.1.12 highestOneBit方法——獲取整數二進制最高位1的索引 39
2.1.13 intValue()方法——獲取int值 40
2.1.14 longValue方法——獲取long值 40
2.1.15 lowestOneBit方法——獲取整數二進制最低位1的索引 41
2.1.16 parseInt方法——將字符串解析為int值 41
2.1.17 reverse方法——反轉整數二進制補碼的位順序 43
2.1.18 reverseBytes方法——反轉整數字節的順序 44
2.1.19 shortValue方法——獲取short值 44
2.1.20 signum方法——獲取整數符號 44
2.1.21 toBinaryString方法——生成整數的二進制字符串 45
2.1.22 toHexString方法——生成整數的十六進制字符串 45
2.1.23 toOctalString方法——生成整數的八進制字符串 46
2.1.24 toString方法——生成整數的十進制字符串 47
2.1.25 valueOf方法——創建Integer對象 49


2.2 Long類——長整型類 50


2.2.1 構造方法——Long類的構造方法 51
2.2.2 常量——Long類的常量 51
2.2.3 bitCount方法——獲取二進制補碼中1的數量 51
2.2.4 byteValue方法——獲取byte值 51
2.2.5 compareTo方法——比較長整數 52
2.2.6 decode方法——字符串解碼為long類型 52
2.2.7 doubleValue方法——返回double數值 53
2.2.8 equals方法——判斷長整數對象相等 53
2.2.9 floatValue方法——獲取float數值 54
2.2.10 getLong方法——獲取長整數的系統屬性值 54
2.2.11 hashCode方法——生成長整數的哈希碼 56
2.2.12 highestOneBit方法——獲取長整數二進制最高位1的索引 56
2.2.13 intValue()方法——獲取int值 57
2.2.14 longValue方法——獲取long值 57
2.2.15 lowestOneBit方法——獲取長整數二進制最低位1的索引 57
2.2.16 parseLong方法——將字符串解析為long值 58
2.2.17 reverse方法——反轉長整數二進制補碼的位順序 60
2.2.18 reverseBytes方法——反轉長整數字節的順序 60
2.2.19 shortValue方法——獲取short值 61
2.2.20 signum方法——獲取長整數符號 61
2.2.21 toBinaryString方法——生成長整數的二進制字符串 61
2.2.22 toHexString方法——生成長整數的十六進制字符串 62
2.2.23 toOctalString方法——生成長整數的八進制字符串 62
2.2.24 toString方法——生成長整數的十進制字符串 63
2.2.25 valueOf方法——創建Long對象 65


2.3 Short類——短整型類 67


2.3.1 構造方法——Short類的構造方法 67
2.3.2 常量——Short類的常量 67
2.3.3 compareTo方法——比較短整數 67
2.3.4 decode方法——字符串解碼為short類型 68
2.3.5 doubleValue方法——返回double數值 68
2.3.6 equals方法——判斷短整數對象相等 68
2.3.7 floatValue方法——獲取float數值 69
2.3.8 hashCode方法——生成短整數的哈希碼 69
2.3.9 intValue()方法——獲取int值 70
2.3.10 longValue方法——獲取long值 70
2.3.11 parseShort方法——將字符串解析為short值 70
2.3.12 reverseBytes方法——反轉短整數字節的順序 72
2.3.13 shortValue方法——獲取short值 72
2.3.14 toString方法——生成短整數的十進制字符串 73
2.3.15 valueOf方法——創建Short對象 73


2.4 Boolean類——布爾類 75


2.4.1 構造方法——Boolean類的構造方法 75
2.4.2 常量——Boolean類的常量 75
2.4.3 booleanValue方法——獲取boolean值 76
2.4.4 compareTo方法——比較布爾值 76
2.4.5 equals方法——判斷相等 77
2.4.6 getBoolean方法——獲取布爾類型的系統屬性值 77
2.4.7 hashCode方法——生成布爾對象的哈希碼 78
2.4.8 parseBoolean方法——將字符串解析成boolean值 78
2.4.9 toString方法——生成布爾值的字符串 78
2.4.10 valueOf方法——創建布爾對象 79


2.5 Byte類——字節對象 80


2.5.1 構造方法——Byte類的構造方法 80
2.5.2 常量——Byte類的常量 80
2.5.3 compareTo方法——比較字節對象 80
2.5.4 decode方法——將字符串解碼為Byte值 81
2.5.5 doubleValue方法——獲取double值 82
2.5.6 equals方法——判斷字節相等 82
2.5.7 floatValue方法——獲取float值 83
2.5.8 hashCode方法——生成字節對象的哈希碼 83
2.5.9 intValue方法——獲取int值 83
2.5.10 longValue方法——獲取long值 83
2.5.11 parseByte方法——將字符串解析為byte值 84
2.5.12 shortValue方法——獲取short值 85
2.5.13 toString方法——生成字節值的十進制字符串 85
2.5.14 valueOf方法——創建Byte對象 86


2.6 Character類——字符類 88


2.6.1 構造方法——Character類的構造方法 88
2.6.2 常量——Character類的常量 88
2.6.3 charCount方法——計算指定字符代碼點的數量 89
2.6.4 charValue方法——獲取char值 89
2.6.5 codePointAt方法——獲取字符數組元素的代碼點 90
2.6.6 codePointBefore方法——獲取字符數組索引前一個元素的代碼點 91
2.6.7 codePointCount方法——返回字符數組的子數組中代碼點的數量 93
2.6.8 compareTo方法——比較字符對象 94
2.6.9 equals方法——判斷字符對象相等 95
2.6.10 getNumericValue方法——返回字符表示的int值 95
2.6.11 getType方法——返回一個指示字符的常規類別的值 97
2.6.12 hashCode方法——生成字符對象的哈希碼 97
2.6.13 isDefined方法——判斷是否為Unicode字符 98
2.6.14 isDigit方法——判斷是否為數字字符 98
2.6.15 isLetter方法——判斷是否為字母字符 99
2.6.16 isLowerCase方法——判斷是否為小寫字符 100
2.6.17 isUpperCase方法——判斷是否為大寫字符 100
2.6.18 toLowerCase方法——轉換為小寫字符 101
2.6.19 toUpperCase方法——轉換為大寫字符 101


2.7 Double——雙精度數字類 102


2.7.1 構造方法——Double類的構造方法 102
2.7.2 常量——Double類的常量 102
2.7.3 byteValue方法——獲取byte值 102
2.7.4 compare方法——比較雙精度數字對象 103
2.7.5 compareTo方法——比較兩個Double對象 103
2.7.6 intValue方法——將此Double值以int形式返回 104
2.7.7 doubleToLongBits方法——返回指定浮點值的表示形式 104
2.7.8 doubleToRawLongBits方法——保留NaN值返回指定浮點值的表示形式 105
2.7.9 doubleValue方法——獲取double值 105
2.7.10 equals方法——判斷Double對象是否相等 106
2.7.11 floatValue方法——獲取float值 107
2.7.12 hashCode方法——生成Double 對象的哈希碼 107
2.7.13 isInfinite方法——判斷Double值的大小是否是無窮大 107
2.7.14 isNaN方法——判斷Double值是否是一個非數字值 108
2.7.15 longBitsToDouble方法——返回給定位表示形式的double值 109
2.7.16 longValue方法——獲取long值 110
2.7.17 parseDouble方法——將字符串解析為double值 110
2.7.18 shortValue方法——獲取short值 110
2.7.19 toHexString方法——生成雙精度數字的十六進制字符串 111
2.7.20 toString方法——生成雙精度數字的十進制字符串 112
2.7.21 valueOf方法——創建Double對象 112


2.8 Float——浮點類 113


2.8.1 構造方法——Float類的構造方法 113
2.8.2 常量——Float類的常量 114
2.8.3 byteValue方法——獲取byte值 114
2.8.4 compare方法——比較Float對象 114
2.8.5 compareTo方法——比較兩個Float對象所表示的數值 115
2.8.6 doubleValue方法——獲取double值 115
2.8.7 equals方法——判斷Double對象相等 115
2.8.8 floatToIntBits方法——返回浮點值的表示形式 116
2.8.9 floatToRawIntBits方法——保留非數字值返回指定浮點值的表示形式 117
2.8.10 floatValue方法——獲取float值 118
2.8.11 hashCode方法——返回Float對象的哈希碼 118
2.8.12 intBitsToFloat方法——返回指定位表示形式的float值 118
2.8.13 intValue方法——獲取int值 119
2.8.14 isInfinite方法——判斷float值的大小是否是無窮大 120
2.8.15 isNaN方法——判斷Float值是否是一個非數字值 120
2.8.16 longValue方法——獲取long值 121
2.8.17 parseFloat方法——將字符串解析成float值 121
2.8.18 shortValue方法——獲取short值 122
2.8.19 toHexString方法——生成浮點數的十六進制字符串 122
2.8.20 toString方法——生成浮點數的十進制字符串 123
2.8.21 valueOf方法——創建浮點數對象 124

 


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 日本中文一级片 | 国产成人自拍视频在线观看 | 成年毛片 | 欧美精品一区二区三区在线 | 91 久久| 成人电影毛片 | 久久精品无码一区二区三区 | 亚洲九色 | 黄色av片在线观看 | 成人黄色小视频在线观看 | 日韩做爰视频免费 | 最新中文字幕第一页视频 | 免费在线观看成人av | 欧美精品色精品一区二区三区 | 狠狠操夜夜爱 | 色999国产| 亚洲国产馆 | 国产一区二区精品在线观看 | 精品一区二区久久久久 | 亚洲国产一区二区三区 | 精品一区二区三区在线观看国产 | 亚洲精品成人久久久 | 一级免费看片 | 一级黄色在线免费观看 | 日本免费一区二区三区四区 | 91久久99热青草国产 | 久久99在线 | 91 免费看片| 在线成人影视 | 久久精品中文字幕一区二区三区 | 国产噜噜噜噜噜久久久久久久久 | 国产精品亚洲一区二区三区在线观看 | 免费毛片电影 | 午夜视频在线免费观看 | 国产亚洲精品久久久久5区 综合激情网 | 国产精品久久久久久久久久了 | 国产精品一区二区三区99 | 欧美一级毛片大片免费播放 | 久久宗合色 | av免费在线网 | 依依成人综合 |