-
Java中使用try-with-resources最核心的优势是让资源释放“不用操心但一定发生”,只要资源实现AutoCloseable,JVM就保证其在try块结束时自动关闭,无论正常执行、return或抛异常。
-
ConcurrentModificationException在单线程遍历时调用集合结构性修改方法(如list.remove())即触发,因迭代器的expectedModCount与集合modCount不匹配;多线程下应选用CopyOnWriteArrayList或ConcurrentHashMap等fail-safe容器。
-
JVM堆内存分代管理,非连续空间:YoungGen(Eden、S0、S1)、OldGen和Metaspace;对象优先分配Eden,触发MinorGC后存活对象复制或晋升,大对象可直接入OldGen;字符串字面量存常量池,newString("abc")仅在堆建引用对象;AllocationFailure是GC正常触发提示,非OOM;逃逸分析可能使对象栈上分配。
-
File类仅是路径抽象,不执行I/O;createNewFile()才真正写磁盘,mkdirs()创建多级目录,exists()需配合isFile()/isDirectory()区分类型,路径分隔符推荐用正斜杠或Paths.get(),JDK7后应优先使用Files/Paths替代。
-
InterruptedException是线程阻塞时被中断抛出的检查异常,JVM会自动清除其中断状态;正确处理方式为捕获后重新设置中断状态或向上抛出,避免空吞、仅记录日志或在finally中调用interrupt()等错误做法,确保中断信号不丢失,支持协作式中断模型。
-
中文乱码需统一源文件编码、IDE内部编码和终端编码:Windows终端用chcp65001,IDE设UTF-8,JVM加-Dfile.encoding=UTF-8,Python需确保终端与文件均为UTF-8无BOM。
-
反射频繁调用会触发动态代理类生成并加载至元空间,若卸载不及时将导致元空间OOM;需通过jstat、jcmd、jmap等工具确认问题,定位高频反射点,禁用膨胀机制(-Dsun.reflect.noInflation=true)或改用MethodHandle/VarHandle优化。
-
SDKMAN!通过.java-version文件实现项目级Java版本切换,但需同步配置Maven/Gradle编译插件、IDESDK及Gradle工具链,三者对齐才能避免环境割裂。
-
newSemaphore(1)不等于synchronized,因前者基于可配置许可数、支持超时与批量获取,后者基于独占monitor机制;关键差异在于资源建模方式与线程协作模型。
-
FileOutputStream写文件为空或不全,因未调用close()或flush()导致缓冲区数据未落盘;应使用try-with-resources确保关闭,追加写需构造时传true;写中文须指定UTF-8编码;大文件应配合BufferedOutputStream优化性能。
-
AtomicBoolean.compareAndSet()能保证单次执行,因其底层基于CPU级CAS指令,原子性完成“判断并更新”,值未被修改才写入新值,否则返回false,精准实现“只做一次”语义。
-
Math类不可实例化,所有方法均为静态,需通过Math.xxx()调用;支持数值类型重载但不处理包装类和null;浮点运算存在精度误差,三角函数默认弧度单位。
-
Instant.parse()仅支持ISO8601格式的UTC时间字符串(如"2024-03-15T14:22:30Z"),不接受空格分隔或带本地时区偏移的时间;从毫秒数构造需用Instant.ofEpochMilli(),避免误用秒级方法导致时间错乱。
-
64位HotSpot虚拟机中对象头默认占12字节,即8字节MarkWord(动态复用存储哈希码、锁状态、GC年龄等)加4字节压缩后的KlassPointer。
-
ByteBuffer.put不能直接写入非byte类型数据,必须用putInt()等专用方法;写入需严格对齐字节序与大小,注意remaining()空间、编码转换及flip()切换读写状态。