诚迈科技Java开发工程师 一面

1. 枚举类能否被继承?为什么?

思路

核心讲枚举类的底层实现(final类+私有构造器),解释无法继承的根本原因。

回答示例

枚举类不能被继承,核心原因是枚举类的底层实现特性:

  1. 编译器会自动将枚举类编译为final class(最终类),而final类无法被继承;
  2. 枚举类的构造器默认被编译器设置为private(私有),子类无法调用父类构造器,不符合继承的语法规则;
  3. 枚举的实例(如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在运行时会执行泛型擦除

  1. 所有泛型类型参数(如 、 )会被擦除为上限类型(无上限则为Object);
  2. 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)通过写时复制+独占锁保证写操作的数据一致性,核心流程:

  1. 写操作(add/set/remove)
  2. 读操作(get/iterator)

核心保证:写操作的复制+锁机制,确保写过程中数组结构不被破坏,读操作无需等待,兼顾并发性能和数据一致性。

5. ArrayBlockingQueue和LinkedBlockingQueue底层结构差异?

思路

从“存储结构、是否有界、锁机制”三个核心维度对比,突出关键差异。

回答示例

维度

Ar

剩余60%内容,订阅专栏后可继续查看/也可单篇购买

本专栏在精不在多,内容分为八股文、大厂真实面经,面试通过后将offer和面试题私发给我,可退还专栏的收益部分费用。欢迎大家共建专栏

全部评论

相关推荐

不愿透露姓名的神秘牛友
03-19 10:38
实力求职者:真的绷不住了,第一张霸总人设,第二张求生欲拉满
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务