Java数据类型
2024/1/16 6:02:21
本文主要是介绍Java数据类型,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
数据类型
包装类型
Java 八个基本类型,基本类型都有对应的包装类型:
基本类型 | 大小(bit) | 最小值 | 最大值 | 默认值 | 包装类 |
---|---|---|---|---|---|
boolean | 1 | - | - | false | Boolean |
char | 16 | Unicode 0 | Unicode 2^16-1 | \u0000(Unicode 0) | Character |
byte | 8 | -128 | 127 | (byte)0 | Byte |
short | 16 | -2^15 | 2^15-1 | (short)0 | Short |
int | 32 | -2^31 | 2^31-1 | 0 | Int |
long | 64 | -2^63 | 2^63-1 | 0L | Long |
float | 32 | - | - | 0.0F | Float |
double | 64 | - | - | 0.0D | Double |
基本类型与其对应的包装类型之间的赋值使用自动装箱与自动拆箱完成。
//自动装箱和自动拆箱 //1、自动装 Integer x=4; //自动装箱 (基本类型转化为包装类型) //实际上就是 Integer x=Integer.valueOf(4); //2、自动拆箱 x=x+5; x=Integer.valueOf(x.intValue()+5);//x.intValue()就是拆箱-->先拆箱,再装箱。
缓存池
Java 基本类型的包装类的大部分都实现了缓存池技术,对应的缓冲池如下:
- Boolean 直接返回 true / false
- Byte/ Short / Integer / Long 创建了数值范围在 [-128,127] 的相应类型的缓存数据
- Character 创建了数值在 [0,127] 的缓存数据
如果超出对应范围仍然会去创建新的对象。
new Integer(123) 与 Integer.valueOf(123) 的区别在于:
- new Integer(123) 每次都会新建一个对象;
- Integer.valueOf(123) 会使用缓存池中的对象,多次调用会取得同一个对象的引用。
Integer x = new Integer(123); Integer y = new Integer(123); System.out.println(x == y); // false Integer z = Integer.valueOf(123); Integer k = Integer.valueOf(123); System.out.println(z == k); // true
valueOf() 方法的实现比较简单,就是先判断值是否在缓存池中,如果在的话就直接返回缓存池的内容。
public static Integer valueOf(int i) { if (i >= IntegerCache.low && i <= IntegerCache.high) return IntegerCache.cache[i + (-IntegerCache.low)]; return new Integer(i); }
在 Java 8 中,Integer 缓存池的大小默认为 -128~127。
static final int low = -128; static final int high; static final Integer cache[]; static { // high value may be configured by property int h = 127; String integerCacheHighPropValue = sun.misc.VM.getSavedProperty("java.lang.Integer.IntegerCache.high"); if (integerCacheHighPropValue != null) { try { int i = parseInt(integerCacheHighPropValue); i = Math.max(i, 127); // Maximum array size is Integer.MAX_VALUE h = Math.min(i, Integer.MAX_VALUE - (-low) -1); } catch( NumberFormatException nfe) { // If the property cannot be parsed into an int, ignore it. } } high = h; cache = new Integer[(high - low) + 1]; int j = low; for(int k = 0; k < cache.length; k++) cache[k] = new Integer(j++); // range [-128, 127] must be interned (JLS7 5.1.7) assert IntegerCache.high >= 127; }
编译器会在自动装箱过程调用 valueOf() 方法,因此多个 Integer 实例使用自动装箱来创建并且值相同,那么就会引用相同的对象。
Integer m = 123; Integer n = 123; System.out.println(m == n); // true
+ 不适用于 Integer 对象,首先 i,j 进行自动拆箱,然后数值相加,得到数值 80,进行自动装箱后,和 m 引用相同的对象。Integer 对象无法与数值直接进行比较,自动拆箱后转为数值 80,显然 80 == 80,输出 true。
Integer i = 40; Integer j = 40; Integer m = 80; System.out.println(m == i+j); // true System.out.println(80 == i+j); // true
这篇关于Java数据类型的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-04百万架构师第六课:设计模式:策略模式及模板模式
- 2025-01-04百万架构师第七课:设计模式:装饰器模式及观察者模式
- 2025-01-04适用于企业管理的协作工具API推荐
- 2025-01-04挑战16:被限流的CPU
- 2025-01-03企业在选择工具时,如何评估其背后的技术团队
- 2025-01-03Angular中打造动态多彩标签组件的方法
- 2025-01-03Flask过时了吗?FastAPI才是未来?
- 2025-01-0311个每位开发者都应知道的免费实用网站
- 2025-01-03从REST到GraphQL:为什么以及我是如何完成转型的
- 2025-01-03掌握RAG:从单次问答到连续对话