欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 新闻 > 国际 > 装箱与拆箱, 包装类的缓存机制

装箱与拆箱, 包装类的缓存机制

2025/6/28 8:40:16 来源:https://blog.csdn.net/m0_63852716/article/details/139586269  浏览:    关键词:装箱与拆箱, 包装类的缓存机制

       前言 

        逆水行舟,不进则退!!!     


       装箱与拆箱      

        自动装箱: 是指将基本类型自动转换为对应的包装类对象的过程. 

        例如: 

Integer y = 5;  // 编译器自动将 int 5 转换为 Integer 对象

        

        自动拆箱: 是指将包装类对象自动转换为对应的基本类型的过程. 

        例如: 

int x = y;  // 编译器自动将 Integer 对象 y 转换为 int

        

        意义在于便利性和代码的简洁性. 自动装箱和拆箱使得在基本数据类型和包装类之间的转换更加方便,减少了代码的冗余性和复杂性。例如,可以直接在需要包装类对象的地方传入基本数据类型,编译器会自动将其转换为对应的包装类对象,而不需要显式地调用构造函数进行转换;同样地,可以直接在需要基本数据类型的地方传入包装类对象,编译器会自动进行拆箱操作. 

      


       缓存机制 

        缓存机制是针对对象实例的, 用于节省内存和提高性能.  应用在整数类型的包装类上. 如: Integer, Byte, Short, Long 这几个包装类. 

        像更常用的 int a = 4;  这行代码并没有涉及到缓存机制, 也没有创建对象; 这是一个简单的基本类型变量声明和初始化的过程. 

        示例代码: 展示了整数缓存机制的应用:

public class IntegerCacheExample {public static void main(String[] args) {Integer a = Integer.valueOf(127); // 使用缓存对象Integer b = Integer.valueOf(127); // 引用相同的缓存对象System.out.println(a == b); // 输出 true,因为 a 和 b 引用了相同的缓存对象Integer c = Integer.valueOf(128); // 超出缓存范围,创建新对象Integer d = Integer.valueOf(128); // 创建另一个新对象System.out.println(c == d); // 输出 false,因为 c 和 d 是不同的对象}
}

         以上示例中,当整数的值在 -128 到 127 范围内时,使用 valueOf 方法创建的 Integer 对象会共享同一个缓存对象。而超出这个范围的值,每次调用 valueOf 方法都会创建一个新的对象


        我是专注学习的章鱼哥~

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词