博客
关于我
Java包装类-自动封箱拆箱
阅读量:354 次
发布时间:2019-03-04

本文共 2339 字,大约阅读时间需要 7 分钟。

包装类

1.Java中的包装类

内置数据类型,如:byte、int、long、double 等。
在实际开发过程中,我们经常会遇到需要使用对象,而不是内置数据类型的情形。为了解决这个问题,Java 语言为每一个内置数据类型提供了对应的包装类。

所有的包装类(Integer、Long、Byte、Double、Float、Short)都是抽象类 Number 的子类。

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
从上面可以看出我们说的包装类实际上就是封装了基本数据的对象的形式,我们看到了,Number类是一个抽象类,是所有数字类型对象的父类,所以每个数值类型的包装类都会实现了Number抽象类的所有抽象方法
在这里插入图片描述



2.举例说明其中的某些方法

首先:构造方法:
在这里插入图片描述

Integer i=new Integer(10);Integer i = new Integer("12");

主要就是以下的两个方法valueOf和xxxVlue方法 就是包装类和基本数据类型的转化方法:

intValue方法将对象类型转为基本数据类型(在其他的包装类中都有相应的xxxValue方法的转换)

Integer i = new Integer(12); int i1 = i.intValue(); System.out.println(i.getClass().getName());   //java.lang.Integer System.out.println(i1);                       //12

基本数据类型转为包装类,用相应包装类的静态方法valueOf方法

Integer i = Integer.valueOf(12);System.out.println(i.getClass().getName());    //java.lang.Integer

还有一个比较重要的静态方法parseXXX将字符串解析为某个基本类型:

public static void main(String[] args) {           double s = Double.parseDouble("123.43");        //int i = Integer.parseInt("123.23");//java.lang.NumberFormatException        System.out.println(s);                                    //123.43        System.out.println(Integer.parseInt("123"));           //123        System.out.println(Double.parseDouble("12"));           //12.0    }

其他的包装类都是类似的,我们进行相应的文档查看就可以

3.自动封箱,自动拆箱

自动装箱就是Java自动将原始类型值转换成对应的对象,比如将int的变量转换成Integer对象,这个过程叫做装箱,反之将Integer对象转换成int类型值,这个过程叫做拆箱。装箱和拆箱是自动进行的非人为转换,所以就称作为自动装箱和拆箱。自动装箱时编译器调用valueOf将原始类型值转换成对象,同时自动拆箱时,编译器通过调用类似intValue(),doubleValue()这类的方法将对象转换成原始类型值。

public static int change(Integer i){       return i.intValue();}    public static void main(String[] args) {           int i=5;        int re = change(i);//自动封箱        System.out.println(re);   //5        Integer i2=new Integer(19);        System.out.println(++i2);              //19  自动拆箱    }

从以上的例子我们可以看出来,change函数需要的是包装类对象,但是我们传入基本类型的数据也可以执行,因为我们在传参后进行了自动封箱,执行了对象的代码,在后面的代码i2对象执行++操作,可以执行的原因是有了自动拆箱的操作,转化为了基本数据类型,才能进行++操作,所以说,封箱拆箱都是自动进行的



重要面试题:

Integer i=127;     Integer i2=127;     System.out.println(i == i2);     Integer j=128;     Integer j2=128;     System.out.println(j==j2);

结果如下:

在这里插入图片描述
这是为什么呢?
同样进行了自动的封箱操作,都转为了对象,但是为什么比较两个内容相同的对象的引用地址会有不同和相同的区别呢?
在这里插入图片描述
在这里插入图片描述
从上面我们可以看出来:JVM在进行类加载的时候,因为-128到127之间的数值是经常被使用的,所以将此范围内的数值提前放到了方法区的整型数常量池当中,所以当我们进行对-128到127间的数值对象进行操作的时候其对象的引用都是在方法区已有对象的直接复用,所以我们无论引用多少次此范围内的对象都是指向的方法区常量池中的同一个对象,但是当我们超出此范围是的Integer对象的时候,就不会在方法区的常量池进行复用,而是在堆中new 对象,尽管数值相同但是==比较的引用地址肯定是不相同的,因为是两个对象。

转载地址:http://vmeq.baihongyu.com/

你可能感兴趣的文章
mapping文件目录生成修改
查看>>
MapReduce程序依赖的jar包
查看>>
mariadb multi-source replication(mariadb多主复制)
查看>>
MariaDB的简单使用
查看>>
MaterialForm对tab页进行隐藏
查看>>
Member var and Static var.
查看>>
memcached高速缓存学习笔记001---memcached介绍和安装以及基本使用
查看>>
memcached高速缓存学习笔记003---利用JAVA程序操作memcached crud操作
查看>>
Memcached:Node.js 高性能缓存解决方案
查看>>
memcache、redis原理对比
查看>>
memset初始化高维数组为-1/0
查看>>
Metasploit CGI网关接口渗透测试实战
查看>>
Metasploit Web服务器渗透测试实战
查看>>
MFC模态对话框和非模态对话框
查看>>
Moment.js常见用法总结
查看>>
MongoDB出现Error parsing command line: unrecognised option ‘--fork‘ 的解决方法
查看>>
mxGraph改变图形大小重置overlay位置
查看>>
MongoDB可视化客户端管理工具之NoSQLbooster4mongo
查看>>
Mongodb学习总结(1)——常用NoSql数据库比较
查看>>
MongoDB学习笔记(8)--索引及优化索引
查看>>