诚迈科技Java开发工程师 一面
1. 枚举类能否被继承?为什么?
思路
核心讲枚举类的底层实现(final类+私有构造器),解释无法继承的根本原因。
回答示例
枚举类不能被继承,核心原因是枚举类的底层实现特性:
- 编译器会自动将枚举类编译为
final class(最终类),而final类无法被继承; - 枚举类的构造器默认被编译器设置为
private(私有),子类无法调用父类构造器,不符合继承的语法规则; - 枚举的实例(如
enum Color {RED, GREEN}中的RED、GREEN)是编译器自动生成的静态常量,无法通过子类扩展。
补充:枚举类可以实现接口(如enum Color implements Runnable),但仍不能继承其他类。
2. @Target注解中ElementType.TYPE_PARAMETER的作用场景?
思路
明确作用(修饰泛型参数)+ 举例说明,区分ElementType.TYPE(修饰类/接口)。
回答示例
ElementType.TYPE_PARAMETER表示注解可以修饰泛型参数(如类/方法的泛型变量),是Java 8新增的类型,核心场景是标注泛型参数的约束。
示例:
// 自定义注解,限定修饰泛型参数
@Target(ElementType.TYPE_PARAMETER)
public @interface MyAnnotation {}
// 使用注解修饰泛型参数T
public class Test<@MyAnnotation T> {
public <@MyAnnotation K> K method(K k) {
return k;
}
}
对比:ElementType.TYPE修饰类/接口/枚举(如@MyAnnotation class Test),而TYPE_PARAMETER仅修饰泛型参数本身。
3. 泛型擦除后,List 和List 在JVM中是否为同一类型?
思路
明确“是同一类型”,解释泛型擦除的本质(类型参数被擦除为Object),补充运行时类型判断逻辑。
回答示例
是同一类型。
泛型是Java的“编译期语法糖”,JVM在运行时会执行泛型擦除:
- 所有泛型类型参数(如 、 )会被擦除为上限类型(无上限则为Object);
List<String>和List<Integer>擦除后都变为原始类型List,JVM运行时无法区分两者;
验证:
List<String> strList = new ArrayList<>(); List<Integer> intList = new ArrayList<>(); System.out.println(strList.getClass() == intList.getClass()); // 输出true
补充:泛型擦除仅影响运行时,编译期编译器会通过类型检查保证泛型安全。
4. CopyOnWriteArrayList写操作时如何保证数据一致性?
思路
核心讲“写时复制”机制,解释写操作的原子性和读操作的无锁特性。
回答示例
CopyOnWriteArrayList(COW)通过写时复制+独占锁保证写操作的数据一致性,核心流程:
- 写操作(add/set/remove):
- 读操作(get/iterator):
核心保证:写操作的复制+锁机制,确保写过程中数组结构不被破坏,读操作无需等待,兼顾并发性能和数据一致性。
5. ArrayBlockingQueue和LinkedBlockingQueue底层结构差异?
思路
从“存储结构、是否有界、锁机制”三个核心维度对比,突出关键差异。
回答示例
维度 |
Ar |
剩余60%内容,订阅专栏后可继续查看/也可单篇购买
本专栏在精不在多,内容分为八股文、大厂真实面经,面试通过后将offer和面试题私发给我,可退还专栏的收益部分费用。欢迎大家共建专栏
查看15道真题和解析