-
ReentrantLock必须手动释放,需在finally块中调用unlock();lock()阻塞获取,tryLock()支持非阻塞或超时;公平锁性能差且仅影响队列线程;Condition实现多条件等待;多数场景优先用synchronized。
-
ResourceLeakDetector仅监控ByteBuf引用计数是否归零及GC时是否释放,不跟踪物理内存池、线程本地缓存或跨线程持有状态;其检测边界是refCnt()为0且对象被GC,而非分配线程或内存页层面的泄露。
-
Long.expand并非Java或Kotlin标准API,JDK21/Kotlin1.9中不存在该方法;它可能源于拼写错误、教学代码中的自定义扩展、或对硬件指令(如PDEP)的误称;典型位展开需手动实现或借助未来VectorAPI。
-
直接继承ClassLoader并重写findClass是最稳妥的自研类加载器方式;loadClass负责双亲委派流程控制,findClass专注字节码读取与defineClass调用,二者解耦且各司其职。
-
SimpleDateFormat线程不安全因其内部calendar和numberFormat状态可变,多线程并发调用parse/format会互相覆盖导致NumberFormatException或日期错乱;正确方案是用ThreadLocal.withInitial()封装并显式设置时区、leniency,或升级至Java8+使用不可变的DateTimeFormatter。
-
通过抽象类定义共通行为,如Animal的makeSound;利用接口实现多维能力,如Flyable;结合策略模式动态切换行为,提升灵活性。
-
当Java类未显式定义构造方法时,编译器会自动生成一个无参的默认构造方法,前提是类不是抽象类且父类构造调用合法;一旦定义了任意构造方法,默认构造方法将不再生成;该默认构造方法无参数、访问权限与类相同,并隐式调用父类无参构造方法;在继承中若父类无无参构造方法且子类未显式调用super(...),则编译失败;因此需注意显式定义无参构造方法以支持反射、序列化等场景。
-
饿汉式单例天然线程安全,因static字段在类加载阶段由JVM同步初始化,确保INSTANCE唯一且无竞态;但存在提前创建、无法传参等问题。
-
动态年龄判断是JVM在MinorGC后实时扫描Survivor区,若某一年龄段对象总和≥Survivor容量50%(默认),则所有≥该年龄对象直接晋升老年代;担保失败则是Survivor空间不足时强制晋升存活对象,无论年龄。
-
链表退化至O(n)时get()性能骤降,JDK1.8通过链表长度≥8且数组容量≥64才转红黑树来优化;红黑树兼顾效率与稳定性,但要求key实现Comparable或传入Comparator,否则树化失败。
-
IntelliJIDEA线程检查仅识别静态模式,如非线程安全集合迭代+修改、synchronized锁局部变量、Date未保护;需显式标注@Shared或跨方法传递才提示;不报ConcurrentModificationException、锁粒度不当或volatile缺失问题。
-
答案:使用JavaSwing实现贪吃蛇游戏,通过JFrame创建窗口,JPanel绘制界面,ArrayList存储蛇身,Timer控制移动,KeyListener处理方向输入,防止反向转向,随机生成食物,检测碰撞与游戏结束。
-
Set能自动去重是因为HashSet等实现类基于hashCode()和equals()判断重复:只有二者均相同才视为重复;自定义类必须同时重写且逻辑一致,否则去重失效。
-
使用get()方法通过key获取Map值,若key不存在则返回null,需结合containsKey()判断以避免空指针;遍历多个key时可用循环处理;使用泛型可提升类型安全和可读性。
-
Java模块化系统结构的核心在于按业务域或技术职责划分清晰边界、可控依赖的独立单元,通过Maven多模块组织、API契约隔离、接口+SPI解耦及异步事件通信实现高内聚低耦合。