最后
针对最近很多人都在面试,我这边也整理了相当多的面试专题资料,也有其他大厂的面经。希望可以帮助到大家。
下面的面试题答案都整理成文档笔记。也还整理了一些面试资料&最新2021收集的一些大厂的面试真题(都整理成文档,小部分截图)
最新整理电子书
}
}
1、泛型类、泛型接口
①泛型的声明
interface List<T>{}
、 class GenTest<K,V>{}
、class student <T extends Person> {}
其中,T,K,V不代表值,而是表示类型。这里使用任意字母都可以,常用T表示,是Type的缩写。
②泛型的实例化
List strList = new ArrayList();
Iterator iterator = customers.iterator();
<>
里面只能是类,不能用基本数据类型填充,可以使用包装类填充。把一个集合中的内容限制为一个特定的数据类型,这就是Generic的核心思想。
泛型类可能有多个参数,此时可将多个参数一起放在尖括号内,如:<E1,E2,E3>
泛型类的构造器与非泛型一样:public GenericClass(){}
,
而public GenericClass<E>(){}
是错误的。
泛型不同的引用不能相互赋值:尽管在编译时ArrayList<String>
和ArrayList<Integer>
是两种类型,但是,在运行时只有一个ArrayList被加载到JVM中。
在类/接口上声明的泛型,在本类或本接口中即代表某种类型,可以作为非静态属性的类型、非静态方法的参数类型、非静态方法的返回值类型。但在静态方法中不能使用类的泛型,因为静态成员是随着类加载而加载的,而类型的指定是在实例化时才确定的。
异常类不能使用泛型。
不能new E[]
,但是可以E[] elements = (E[])new Object[capacity];
。
父类有泛型,子类可以选择保留泛型也可以选择指定泛型类型,子类除了指定或保留父类的泛型,还可以增加自己的泛型:
class Father<T1, T2> {
}
// 子类不保留父类的泛型
// 1)没有类型 擦除
class Son1 extends Father {// 等价于class Son extends Father<Object,Object>{
}
// 2)指定类型
class Son2 extends Father<Integer, String> {
}
// 子类保留父类的泛型
// 1)全部保留
class Son3<T1, T2> extends Father<T1, T2> {
}
// 2)部分保留
class Son4 extends Father<Integer, T2> {
}
class Father<T1, T2> {
}
// 子类不保留父类的泛型
// 1)没有类型 擦除
class Son<A, B> extends Father{//等价于class Son extends Father<Object,Object>{
}
// 2)具体类型
class Son2<A, B> extends Father<Integer, String> {
}
// 子类保留父类的泛型
// 1)全部保留
class Son3<T1, T2, A, B> extends Father<T1, T2> {
}
// 2)部分保留
class Son4<T2, A, B> extends Father<Integer, T2> {
}
class Person {
// 使用T类型定义变量
private T info;
// 使用T类型定义一般方法
public T getInfo() {
return info;
}
public void setInfo(T info) {
this.info = info;
}
// 使用T类型定义构造器
public Person() {
}
public Person(T info) {
this.info = info;
}
}
2、泛型方法
方法,也可以被泛型化,不管此时定义在其中的类是不是泛型类。在泛型方法中可以定义泛型参数,此时,参数的类型就是传入数据的类型。
访问权限 是否为静态 <泛型> 返回类型 方法名(泛型标识 参数名称,…) 异常{
//方法体
}
public class Test {
public E get(int id, E[] arry) {
E result = null;
return result;
}
}
如果B是A的一个子类型(子类或者子接口),而G是具有泛型声明的类或接口,G<B>
并不是G<A>
的子类型!比如:String是Object的子类,但是List<String>
并不是List<Object>
的子类,不能相互赋值。而反过来,如下是可以的:
ArrayList arrayList = new ArrayList<>();
List list = arrayList;
1、使用
比如:List<?>
,Map<?,?>
,
List<?>
是List<String>
、List<Object>
等各种泛型List的父类。
读取List<?>
的对象list中的元素时,永远是安全的,因为不管list的真实类型是什么,都包含于Object。而不能向其中添加(写入)对象。除了null,因为它是所有类型的成员:
Collection<?> c = new ArrayList();
c.add(new Object()); // 编译时错误
public static void main(String[] args) {
List<?> list = null;
list = new ArrayList();
list = new ArrayList();
list.add(3);//编译不通过,编译时错误
list.add(null);
List l1 = new ArrayList();
List l2 = new ArrayList();
总结
我们总是喜欢瞻仰大厂的大神们,但实际上大神也不过凡人,与菜鸟程序员相比,也就多花了几分心思,如果你再不努力,差距也只会越来越大。
面试题多多少少对于你接下来所要做的事肯定有点帮助,但我更希望你能透过面试题去总结自己的不足,以提高自己核心技术竞争力。每一次面试经历都是对你技术的扫盲,面试后的复盘总结效果是极好的!
如果你再不努力,差距也只会越来越大。
面试题多多少少对于你接下来所要做的事肯定有点帮助,但我更希望你能透过面试题去总结自己的不足,以提高自己核心技术竞争力。每一次面试经历都是对你技术的扫盲,面试后的复盘总结效果是极好的!
[外链图片转存中…(img-niMWehLv-1715450798979)]