java 自动装箱与拆箱

来源:互联网 发布:淘宝魔兽账号被找回 编辑:程序博客网 时间:2024/05/18 03:24
作者:尹鹏程
链接:https://zhuanlan.zhihu.com/p/22168957
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

java语言规范中说道:在许多情况下包装与解包装是由编译器自行完成的(在这种情况下包装成为装箱,解包装称为拆箱);

Java为每个原始类型提供了封装类。

原始类型 封装类
boolean Boolean
char Character
byte Byte
short Short
int Integer
long Long
float Float
double Double

其实按照我自己的理解自动装箱就可以简单的理解为将基本数据类型封装为对象类型,来符合java的面向对象;例如用int来举例:


//声明一个Integer对象Integer num = 10;//以上的声明就是用到了自动的装箱:解析为Integer num = new Integer(10);

以上就是一个很好的体现,因为10是属于基本数据类型的,原则上它是不能直接赋值给一个对象Integer的,但jdk1.5后你就可以进行这样的声明,这就是自动装箱的魅力
自动将基本数据类型转化为对应的封装类型。成为一个对象以后就可以调用对象所声明的所有的方法

自动拆箱:顾名思义就是将对象重新转化为基本数据类型:


//装箱Integer num = 10;//拆箱int num1 = num;

自动拆箱有个很典型的用法就是在进行运算的时候:因为对象时不能直接进行运算的,而是要转化为基本数据类型后才能进行加减乘除


Integer num = 10;//进行计算时隐含的有自动拆箱System.out.print(num--);

哈哈 应该感觉很简单吧,下面我再来讲点稍微难点的,是稍微
看下面一个例子,在看下面一个例子时如果对于 == 与 equal的区别不清楚的,可以先看java中 == 与 equal 的区别


//在-128~127 之外的数         Integer num1 = 297;   Integer num2 = 297;                    System.out.println("num1==num2: "+(num1==num2));                             // 在-128~127 之内的数          Integer num3 = 97;   Integer num4 = 97;            System.out.println("num3==num4: "+(num3==num4)); 

打印的结果是:num1==num2: false num3==num4: true

很奇怪吧:这就归结于java对于Integer与int的自动装箱与拆箱的设计,是一种模式:叫享元模式(flyweight)

为了加大对简单数字的重利用,java定义:在自动装箱时对于值从–128到127之间的值,它们被装箱为Integer对象后,会存在内存中被重用,始终只存在一个对象

而如果超过了从–128到127之间的值,被装箱后的Integer对象并不会被重用,即相当于每次装箱时都新建一个 Integer对象;明白了吧

以上的现象是由于使用了自动装箱所引起的,如果你没有使用自动装箱,而是跟一般类一样,用new来进行实例化,就会每次new就都一个新的对象;


另一个重用例子

        String str1 = new String("str");        String str2 = new String("str");        System.out.println("==比较 :"+ (str1 == str2));        System.out.println("equal比较:"+ str1.equals(str2));        String str3 = "str1";        String str4 = "str1";        System.out.println("==比较 :"+ (str3 == str4));        System.out.println("equal比较:"+ str3.equals(str4));

false

equal比较:true

true

equal比较:true

原因:
当使用new时会新申请一个内存区,所以使用==比较为false,
而当使用=直接赋值时,会先检查内存是否有相同的字符串,如果有则将引用指向该内存区,故使用==比较为true


0 0
原创粉丝点击