我是靠谱客的博主 热心西装,最近开发中收集的这篇文章主要介绍java int integer_浅谈java中int和Integer的区别,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

第一,简介

int是java的8个原始数据类型(boolean, byte, short, char, int, float, double, long)之一。java虽然号称一切皆是对象,但原始数据类型除外。

integer是int对应的包装类,它有一个int类型的字段存储数据,并提供了数学运算,int和字符串之间转换等基本操作。在java5中,引入了自动装箱和自动拆箱功能,并新增了静态工厂方法valueof,在调用它的时候回利用一个缓存机制,这个缓存默认值是-128到127之间。所有的包装类都被声明为"private final",所以,它们同样是不可变类型。

第二,知识扩展

1,理解自动装箱,拆箱。自动装箱实际上算是一种语法糖。也就是java为我们自动进行一些转换,保证不同的写法在运行时等价,它们发生在编译阶段,也就是生成的字节码是一致的。javac替我们自动把装箱转换为integer.valueOf(),把拆箱替换为integer.intValue()。这种缓存机制也存在其他一些包装类,比如:Boolean, Short, Byte, Character。

2,自动装箱,拆箱在编码中的注意事项。原则上建议避免无意中的装箱,拆箱行为,尤其是性能敏感的场合,创建10万个java对象和10万个整数的开销可不是一个数量级的,不管是内存使用还是处理速度,光是对象的空间占用就已经是数量级的差距了。使用原始数据类型,数组甚至本地代码实现等,在性能极度敏感的场景往往具有比较大的优势,用其替换掉包装类,动态数组(如ArrayList)等可以作为性能优化的备选项。

3,java原始数据类型和引用类型局限性。首先数据类型和java泛型某种程度上可以算作伪泛型,它完全是一种编译器的技巧,java编译期会自动将类型转换为对应的特定类型,这就决定了使用泛型,必须保证相应类型可以转换为Object。第二,无效高效的表达数据,也不便于表达复杂的数据结构。java对象都是引用类型,如果是一个原始数据类型数组,它在内存里是一段连续的内存,而对象数组是无序的分散在堆的不同位置。这种设计虽然灵活,但也导致了数据操作的低效,尤其是无法充分利用现代CPU缓存机制。

4,原始类型的线性安全问题。原始数据类型的变量,显然要使用并发先关手段,才能保证线程安全。特别是部分比较宽的数据类型,比如float,double,甚至不能保证更新操作的原子性,可能出现程序读取到只更新了一半数据位的数值。如果有线程安全的计算需要,建议考虑使用类似Atomicinteger,AtomicLong这样的线程安全类。

第三,运用场景

1,因为比如Integer i = 128;java在编译Integer i = 128的时候,被翻译成 Integer i = Integer.valueOf(128);所以无论如何,Integer与new Integer不会相等。都不会经历拆箱过程,直接是两个对象的比较。

2,两个都是非new出来的Integer,如果数在-128到127之间,则是true,否则为false,因为valueOf()函数会对-128到127之间的数进行缓存。如果数值在-128到127之间则取缓存对象,否则重新new一个新对象。

3,两个都是new Integer,是两个对象进行比较,比较都为false。

4,int和integer(无论new否)比,都为true,因为会把Integer自动拆箱为int再去比。

举例:

46ea640a1424

为什么i4和i5比是true,而i6和i7比是false呢?关键就是看valueOf()函数了,这个函数对于-128到127之间的数,会进行缓存, Integer i4 = 127时,会将127进行缓存,下次再写Integer i5 = 127时,就会直接从缓存中取,就不会new了。所以i4和i5比是true,而i6和i7大于127所以都需要new出来所以最后比是false。

最后

以上就是热心西装为你收集整理的java int integer_浅谈java中int和Integer的区别的全部内容,希望文章能够帮你解决java int integer_浅谈java中int和Integer的区别所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(34)

评论列表共有 0 条评论

立即
投稿
返回
顶部