Java是一个面向对象的编程语言,但其基本数据类型(如int、char、boolean等)并不直接支持面向对象的特性。为了弥补这一不足,Java为每种基本数据类型设计了一个对应的类,这些类统称为包装类(Wrapper Class)。包装类均位于java.lang
包中。
装箱(Boxing)和拆箱(Unboxing)是Java语言中关于基本数据类型(primitive types)和它们对应的包装类(wrapper classes)之间转换的两个重要概念。
int
类型转换为 Integer
类型。int a = 10;
Integer ii = Integer.valueOf(a); //显示装箱 or 手动装箱
Integer jj = a; //隐式装箱 or 自动装箱
我们查看这段代码的汇编代码可以发现,两种装箱底层都是调用的 valueOf()
方法
Integer
类型转换为 int
类型。Integer ii = 10;
int a = ii; //自动拆箱
int b = ii.intValue(a); //手动拆箱
我们查看这段代码的汇编代码可以发现,两种拆箱底层都是调用的 intValue()
方法
//判断两次输出分别是什么
Integer a = 100;
Integer b = 100;
System.out.println(a==b);
Integer c = 200;
Integer d = 200;
System.out.println(c==d)
答案:true false 解析:
valueOf()
方法
if
判断条件可知,i
如果是在 [-128, 127]
之间,就是返回一个数组的值IntegerCache.cache[100-(-128)] = IntegerCache.cache[228]
,故 a == b
为 true
c == d
为 false
举例:
Object[]
数组,Object 使得这个数组可以放下任何类型的数据setArray(int pos, Object obj)
方法,用来在第 pos
位上存放数据 obj
Object getArray(int pos)
方法,用来返回第 pos
位的值pos = 1
的地方,传入一个 obj = 10
之后,当准备创建一个 int a
来接收 array[1]
这个值的时候,程序确保错了
getArray()
方法为了可以让数组能返回任意类型的数据,返回类型设置成了 Object
int
类型取出这个数据的时候,由于类型不匹配,导致报错Object
的类型转化为 int
public class MyArray {
public Object[] array = new Object[10];
public void setArray(int pos, Object obj) {
array[pos] = obj;
}
public Object getArray(int pos) {
return array[pos];
}
public static void main(String[] args) {
MyArray myArray = new MyArray();
myArray.setArray(1,3);
int a = (int) myArray.getArray(1);
}
}
class 泛型类名称<类型形参列表> { // 这里可以使用类型参数
}
class ClassName<T1, T2, ..., Tn> { }
class 泛型类名称<类型形参列表> extends 继承类 { }
class ClassName<T1, T2, ..., Tn> extends ParentClass<T1> { }
public class MyArray<T> {
public Object[] array = new Object[10];
public void setArray(int pos, T obj) {
array[pos] = obj;
}
public T getArray(int pos) {
return (T) array[pos];
}
public static void main(String[] args) {
MyArray<Integer> myArray = new MyArray<>();
myArray.setArray(1,3);
Integer a = myArray.getArray(1);
}
}
T类型
来存放的,最后取出的时候是按照 Integer类型
来检查的,若索取出的值和实例化中 <>
内的类型一直,则可取出,反之报错< >:
extends
关键字(在Java中)来指定,用于声明一个类型参数必须是某个特定类或接口(或其子类/实现类)的实例。这允许在编译时进行更严格的类型检查,防止类型不匹配的错误public class MyArray<E extends Number> { //只接受Number的子类型或Number本身作为E的类型实参
...
}
public class MyArray<E extends Comparable<E>> { //E必须是实现了Comparable接口的
...
}
<>
包围。public <T extends Comparable<T>> T findMax(T[] array){
T max = array[0];
for(int i = 1; i < array.length; i++){
if(array[i].compareTo(max) > 0){
max = array[i];
}
}
return max;
}