为什么要提供包装类呢? 比如说有这样的需求,我们有一个方法,里面的参数类型是Object类型,但是需要我们传一个数字进去,由于数字是基本数据类型,无法传入,所以需要用到包装类 Number是抽象类,无法实例化对象 包装类属于引用数据类型
- 针对八种基本数据类型相应的引用类型—包装类
- 有了类的特点,就可以调用类中的方法。
- 如图:
JDK5.0以前,要手动装箱和拆箱
JDK5.0以后,可以自动装箱和拆箱
基本数据类型----->引用数据类型(装箱)
Integer i=new Integer(10);
引用数据类型------->基本数据类型(拆箱)
float f=Integer.floatValue(i);
字符串类型------>引用数据类型
Integer i=new Integer("123");
//演示 int <--> Integer 的装箱和拆箱
//jdk5 前是手动装箱和拆箱
//手动装箱 int->Integer
int n1 = 100;
Integer integer = new Integer(n1);
Integer integer1 = Integer.valueOf(n1);
//手动拆箱
//Integer -> int
int i = integer.intValue();
//jdk5 后,就可以自动装箱和自动拆箱
int n2 = 200;
//自动装箱 int->Integer
Integer integer2 = n2; //底层使用的是 Integer.valueOf(n2)
//自动拆箱 Integer->int
int n3 = integer2; //底层仍然使用的是 intValue()方法
注意: 在进行转换的时候,可能报异常,比如说你想把字符串转换成Integer,如果字符串里面的内容不是整数,就会出现异常
Integer i=new Integer("1b3");
System.out.println(i);
会报错,
java.lang.NumberFormatException.forInputString
测试题:
以 Integer 和 String 转换为例,其它类似:
包装类(Integer)->String
Integer i = 100;//自动装箱
//方式 1
String str1 = i + "";
//方式 2
String str2 = i.toString();
//方式 3
String str3 = String.valueOf(i);
//String -> 包装类(Integer)
String str4 = "12345";
Integer i2 = Integer.parseInt(str4);//使用到自动装箱
Integer i3 = new Integer(str4);//构造器
包装类,字符串,基本数据类型转换的总结:
public class WrapperMethod {
public static void main(String[] args) {
System.out.println(Integer.MIN_VALUE); //返回最小值
System.out.println(Integer.MAX_VALUE);//返回最大值
System.out.println(Character.isDigit('a'));//判断是不是数字
System.out.println(Character.isLetter('a'));//判断是不是字母
System.out.println(Character.isUpperCase('a'));//判断是不是大写
System.out.println(Character.isLowerCase('a'));//判断是不是小写
System.out.println(Character.isWhitespace('a'));//判断是不是空格
System.out.println(Character.toUpperCase('a'));//转成大写
System.out.println(Character.toLowerCase('A'));//转成小写
}
}
包装类没有无参构造方法,而且所有包装类的实例都是不可变的,说明一旦创建对象,它们的内部值就不能再改变了
MAX_VALUE表示对应的基本数据类型的最大值
MIN_VALUE表示对应的基本数据类型的最小值
池其实就是缓存机制 cashe
Integer类加载的时候会初始化整数型常量池:256给对象
缓存的优点:效率高,可以直接用
缺点:占用内存大,耗费内存
public static void main(String[] args) {
Integer i = new Integer(1);
Integer j = new Integer(1);
System.out.println(i == j); //False
Integer m = 1; //底层 Integer.valueOf(1); -> 阅读源码
Integer n = 1;//底层 Integer.valueOf(1);
System.out.println(m == n); //T
//所以,这里主要是看范围 - 128 ~ 127 就是直接返回
// ,否则,就 new Integer(xx);
Integer x = 128;//底层 Integer.valueOf(1);
Integer y = 128;//底层 Integer.valueOf(1);
System.out.println(x == y);//False
}
}
所以,这里主要是看范围 - 128 ~ 127 就是直接返回
- 如果 i 在 IntegerCache.low(- 128)~IntegerCache.high(127),就直接从数组返回
- 如果不在 - 128~ 127,就直接 new Integer(i)
- 源码:
public static Integer valueOf(int i) {
if (i >= IntegerCache.low && i <= IntegerCache.high)
return IntegerCache.cache[i + (-IntegerCache.low)];
return new Integer(i);
}
注意: 只要有基本数据类型,判断的是值是否相同
Integer i11=127;
int i12=127;
//只有有基本数据类型,判断的是
//值是否相同
System.out.println(i11==i12); T
//示例七
Integer i13=128;
int i14=128;
System.out.println(i13==i14);T
本文为互联网自动采集或经作者授权后发布,本文观点不代表立场,若侵权下架请联系我们删帖处理!文章出自:https://zengyihong.blog.csdn.net/article/details/123166189