博客
关于我
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/

你可能感兴趣的文章
mysql replace first,MySQL中处理各种重复的一些方法
查看>>
MySQL replace函数替换字符串语句的用法(mysql字符串替换)
查看>>
mysql replace用法
查看>>
Mysql Row_Format 参数讲解
查看>>
mysql select, from ,join ,on ,where groupby,having ,order by limit的执行顺序和书写顺序
查看>>
MySQL Server 5.5安装记录
查看>>
mysql server has gone away
查看>>
mysql slave 停了_slave 停止。求解决方法
查看>>
MySQL SQL 优化指南:主键、ORDER BY、GROUP BY 和 UPDATE 优化详解
查看>>
MYSQL sql语句针对数据记录时间范围查询的效率对比
查看>>
mysql sum 没返回,如果没有找到任何值,我如何在MySQL中获得SUM函数以返回'0'?
查看>>
mysql Timestamp时间隔了8小时
查看>>
Mysql tinyint(1)与tinyint(4)的区别
查看>>
mysql union orderby 无效
查看>>
mysql v$session_Oracle 进程查看v$session
查看>>
mysql where中如何判断不为空
查看>>
MySQL Workbench 使用手册:从入门到精通
查看>>
mysql workbench6.3.5_MySQL Workbench
查看>>
MySQL Workbench安装教程以及菜单汉化
查看>>
MySQL Xtrabackup 安装、备份、恢复
查看>>