Java包装类

本文阅读 4 分钟
首页 代码,Java 正文

为什么要提供包装类呢? 比如说有这样的需求,我们有一个方法,里面的参数类型是Object类型,但是需要我们传一个数字进去,由于数字是基本数据类型,无法传入,所以需要用到包装类 img Number是抽象类,无法实例化对象 包装类属于引用数据类型

  1. 针对八种基本数据类型相应的引用类型—包装类
  2. 有了类的特点,就可以调用类中的方法。
  3. 如图: img img img

img

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

img 测试题: img

以 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'));//转成小写

}
}

img

包装类没有无参构造方法,而且所有包装类的实例都是不可变的,说明一旦创建对象,它们的内部值就不能再改变了

MAX_VALUE表示对应的基本数据类型的最大值

MIN_VALUE表示对应的基本数据类型的最小值

img img img img 池其实就是缓存机制 cashe

Integer类加载的时候会初始化整数型常量池:256给对象

缓存的优点:效率高,可以直接用

缺点:占用内存大,耗费内存 img

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 就是直接返回

  1. 如果 i 在 IntegerCache.low(- 128)~IntegerCache.high(127),就直接从数组返回
  2. 如果不在 - 128~ 127,就直接 new Integer(i)
  3. 源码:
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
-- 展开阅读全文 --
安全面试之XSS(跨站脚本攻击)
« 上一篇 07-24

发表评论

成为第一个评论的人

热门文章

标签TAG

最近回复