-
Java中的不可变集合指List.of()、Set.of()、Map.of()等返回的真正不可修改实例,创建后大小、元素、顺序均不可变,任何修改操作抛UnsupportedOperationException,且不共享可变状态;而Collections.unmodifiableXXX()仅为只读代理,原始集合仍可变。
-
构造函数抛出IOException会导致对象半初始化问题。因部分副作用无法回滚、破坏依赖注入与链式调用、抑制JVM逃逸分析优化,应改用静态工厂方法封装异常。
-
线程中断是协作机制,调用interrupt()仅设置中断状态;2.任务需主动检查状态或处理InterruptedException实现取消;3.阻塞方法可抛出该异常并清除状态;4.Future.cancel(true)利用中断取消任务;5.不可中断操作应使用可中断替代方案或超时机制;6.关键是任务自我感知中断并优雅退出。
-
Java中对象创建有四种方式:new、反射(Constructor.newInstance)、Class.forName().newInstance(已过时)、反序列化(ObjectInputStream.readObject);对象进入可回收状态取决于根可达性分析,不可达即待回收;finalize已废弃,应使用Cleaner或PhantomReference;对象销毁无确定时间点,资源须显式释放。
-
本文介绍一种简洁、健壮且空间友好的Java实现,用于在动态追加元素的整数列表中实时检测是否存在任意三个连续元素之和等于给定值,避免原代码中冗余子列表缓存与越界风险。
-
封装、继承、多态是Java面向对象三大特性。1.封装通过private隐藏字段,提供getter/setter安全访问,保护数据;2.继承使用extends复用父类非私有成员,建立类层次,支持单继承;3.多态通过父类引用指向子类对象,重写方法实现不同行为,运行时动态调用,提升灵活性。三者结合增强代码可维护性、扩展性与复用性。
-
n&1能判断奇偶是因为整数以二进制补码存储,最低位为0是偶数、为1是奇数;n&1仅保留最低位,结果为0或1,比取模、除法更高效且支持负数。
-
InvocationTargetException是什么,为什么它总在反射里冒出来它不是你代码写错了,而是被反射调用的那个方法自己抛了异常,InvocationTargetException只是“套壳”——把原始异常包了一层再扔出来。JVM要求反射调用必须统一用这个包装类,否则没法区分“反射失败”和“目标方法失败”。常见错误现象:InvocationTargetException堆栈里看不到你写的业务异常,只看到getCause()才是真凶;IDE调试时断点停在invoke()那行,
-
Collections.frequency适用于单元素频次统计,语义清晰但仅支持精确equals比较;Stream.groupingBy适合全量频次统计,性能更优但需注意null键和自定义对象的equals/hashCode实现。
-
CharArrayReader是Java中用于直接读取内存中char[]数组的轻量级字符输入流,无I/O开销、零拷贝、响应快,适用于需将已有字符数组作为Reader传入流式API的场景。
-
ConcurrentHashMap的putIfAbsent不是绝对原子,因其仅对key插入做CAS保护,value构造副作用(如new对象)仍会执行;正确做法是用computeIfAbsent延迟构造。
-
不推荐直接用Executors创建线程池,因其默认无界队列易致内存溢出、未指定线程工厂、缺乏自定义拒绝策略;阿里Java手册明确禁止,推荐直接使用ThreadPoolExecutor。
-
静态类变量线程不安全,需通过synchronized锁、原子类、volatile(仅限简单赋值)、ThreadLocal或改用实例变量等方式保障线程安全。
-
无符号右移(>>>)将整数二进制位序列整体右移,高位恒补0,不考虑符号位,使负数转为非负大整数;需基于补码理解,注意类型提升、移位量取模及不可用于取绝对值。
-
MyBatis3.4+要求JDK8+,JDK11+需添加jakarta.xml.bind-api;配置文件须置于classpath根路径;MySQL8驱动需指定serverTimezone;MapperXML必须在mybatis-config.xml中注册且namespace与接口全限定名一致。