我们知道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
以上就是包装类的内容,更多相关内容请关注PHP中文网(www.php.cn)!

RSS和XML是用于网络内容管理的工具。RSS用于发布和订阅内容,XML用于存储和传输数据。它们的工作原理包括内容发布、订阅和更新推送。使用示例包括RSS发布博客文章和XML存储书籍信息。

RSS文档是基于XML的结构化文件,用于发布和订阅频繁更新的内容。它的主要作用包括:1)自动化内容更新,2)内容聚合,3)提高浏览效率。通过RSSfeed,用户可以订阅并及时获取来自不同来源的最新信息。

RSS的XML结构包括:1.XML声明和RSS版本,2.频道(Channel),3.条目(Item)。这些部分构成了RSS文件的基础,允许用户通过解析XML数据来获取和处理内容信息。

RSSFEEDSUSEXMLTOSYNDICATECONTENT; PARSINGTHEMINVOLVESLOADINGINGINGINGINSSTRUCTURE,andExtractingData.ApplicationsIncludeBuildBuildingNewSagGregatorSaterNewSagGregatorSator andTrackingPodcastepodcastepisodes。

RSS文档的工作原理是通过XML文件发布内容更新,用户通过RSS阅读器订阅并接收通知。1.内容发布者创建并更新RSS文档。2.RSS阅读器定期访问并解析XML文件。3.用户浏览和阅读更新内容。使用示例:订阅TechCrunch的RSS源,只需复制链接到RSS阅读器中即可。

使用XML构建RSSfeed的步骤如下:1.创建根元素并设置版本;2.添加channel元素及其基本信息;3.添加条目(item)元素,包括标题、链接和描述;4.转换XML结构为字符串并输出。通过这些步骤,你可以从零开始创建一个有效的RSSfeed,并通过添加额外的元素如发布日期和作者信息来增强其功能。

创建RSS文档的步骤如下:1.使用XML格式编写,根元素为,包含元素。2.在内添加、、等元素描述频道信息。3.添加元素,每个代表一个内容条目,包含、、、等。4.可选地添加和元素,丰富内容。5.确保XML格式正确,使用在线工具验证,优化性能并保持内容更新。

XML在RSS中的核心作用是提供一种标准化和灵活的数据格式。1.XML的结构和标记语言特性使其适合数据交换和存储。2.RSS利用XML创建标准化格式,方便内容共享。3.XML在RSS中的应用包括定义feed内容的元素,如标题和发布日期。4.优势包括标准化和可扩展性,挑战包括文件冗长和严格语法要求。5.最佳实践包括验证XML有效性、保持简洁、使用CDATA和定期更新。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

SublimeText3 Linux新版
SublimeText3 Linux最新版

SublimeText3汉化版
中文版,非常好用

Atom编辑器mac版下载
最流行的的开源编辑器

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)