码迷,mamicode.com
首页 > 编程语言 > 详细

JAVA中Integer对象的引用

时间:2015-04-07 00:47:51      阅读:162      评论:0      收藏:0      [点我收藏+]

标签:指针   integercache   java引用   整型比较   

JAVA中没有指针一说,但也有引用的概念。这里要说的主要是Integer是不是同一个对象。

1、先看一段代码:

public static void main(String[] args){
		Integer a1 = 100;
		Integer b1 = a1;//另一种也可以b1=100
		Field field = null;
		try {
			field = a1.getClass().getDeclaredField("value");
		} catch (NoSuchFieldException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (SecurityException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}  
		  
        field.setAccessible(true);  

        try {
			field.set(a1, 5000);
		} catch (IllegalArgumentException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (IllegalAccessException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}  
        System.out.println("b1="+b1);
        
        Integer c1 = 100;
        System.out.println("c1="+c1);
        
	}

结果:

b1=5000
c1=5000

从上面,首先这里要说明几个,

1)、对于Integer来说,-128-127之间的整型已经初始化放在IntegerCache中,如果是装箱的话,就会从这里面取对象。

2)、b1=a1到底是数字赋值还是同一个对象?这个从结果实际就可以看出来,b1和a1指向同一个对象,而不是同一个数值

3)、c1=100,说明对于-128-127之间的数值,都是从IntegerCache中获取的对象,100对应的Integer对象被改变后,后续对于100的装箱都被改变。因为获取cache中对象时用的是数组索引,而不是数值比较获取的。

不过修改这个缓存会比较危险,不介意。谁知道什么jar包或者什么平台来个100的装箱,但得到结果又不是100,到时就崩溃了。


2、通过上面描述,那么如果改成这样又是什么答案

public static void main(String[] args){
		Integer a1 = 200;
		Integer b1 = a1;
		Field field = null;
		try {
			field = a1.getClass().getDeclaredField("value");
		} catch (NoSuchFieldException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (SecurityException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}  
		  
        field.setAccessible(true);  

        try {
			field.set(a1, 5000);
		} catch (IllegalArgumentException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (IllegalAccessException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}  
        System.out.println("b1="+b1);
        
        Integer c1 = 200;
        System.out.println("c1="+c1);
        
	}

3、那么再改一下

public static void main(String[] args){
		Integer a1 = new Integer(100);
		Integer b1 = a1;
		Field field = null;
		try {
			field = a1.getClass().getDeclaredField("value");
		} catch (NoSuchFieldException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (SecurityException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}  
		  
        field.setAccessible(true);  

        try {
			field.set(a1, 5000);
		} catch (IllegalArgumentException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (IllegalAccessException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}  
        System.out.println("b1="+b1);
        
        Integer c1 = 100;
        System.out.println("c1="+c1);
        
	}
这又是什么答案。对于new的操作,是不进行装箱的,而是在堆中生成对象的。

理解了装箱、缓存、引用就不难理解了。可以自己试试。


JAVA中Integer对象的引用

标签:指针   integercache   java引用   整型比较   

原文地址:http://blog.csdn.net/danielinbiti/article/details/44907625

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!