-
CLASSPATH是JVM定位.class和.jar的路径列表,JDK5+默认包含当前目录(.),通常无需手动设置;显式使用-cp时会完全忽略系统CLASSPATH,优先级为:-cp>环境变量>默认值。
-
应优先使用NumberFormat.getCurrencyInstance(Locale)获取区域敏感的货币格式器,而非直接使用DecimalFormat;因后者不绑定Locale且无视币种小数规则,易导致符号错误或非法小数位。
-
课程表自动生成需解决多资源冲突,首先定义课程、教师、教室、班级和时间段等类,建立无时间冲突、满足连堂及资源限制的约束条件,接着使用回溯算法尝试排课,对难排课程优先处理以提升效率,最后输出二维表格形式课表。关键在于准确建模约束并结合启发式策略优化搜索过程,确保课时排完且不超教师负荷。
-
Collection必须实现15个核心方法:增删查基础操作(add、remove、contains、size、isEmpty)、批量操作(addAll、removeAll、retainAll、containsAll、clear)、遍历转换(iterator、toArray、toArray(T[])),以及JDK8+默认方法(stream、parallelStream、removeIf)。
-
TLAB是什么,为什么每个线程要自己分一块小内存TLAB(ThreadLocalAllocationBuffer)是JVM在堆内存中为每个线程单独划出的一小块连续空间,专供该线程快速分配对象。它不是独立于堆之外的区域,而是Eden区内的“私有子区”。没有TLAB时,所有线程都要竞争Eden的公共指针(如top),频繁加锁或CAS,成为性能瓶颈;启用后,线程直接在自己的缓冲区里挪动本地指针,几乎无竞争。常见错误现象:GClogs里看到大量TLABwaste或TLA
-
compactconstructor是record中唯一能在this()前执行校验的合法位置,用于保障对象创建时状态合法;禁止赋值final字段,仅支持参数校验与异常抛出,统一用IllegalArgumentException或IllegalStateException。
-
不能只靠publicstaticfinalint管理状态码,因其缺乏编译期校验、耦合分散、易出错且不可枚举;推荐用enum实现,天然支持字段、方法、序列化与安全查找。
-
自增自减分前置和后置,前置先运算后取值,后置先取值后运算,常用于循环和计数,需注意执行顺序以避免逻辑错误。
-
不存在“OpenS语法”;主流方案是用反射(C#/Java)或直接赋值(Python)填充私有变量,推荐通过重构提升可测性而非依赖语法技巧。
-
Scanner.hasNext(Pattern)是阻塞的,因System.in底层为阻塞流,无法超时或取消等待;真正非阻塞需用NIO、Console.ready()或线程+超时封装,但推荐重构交互逻辑避免此需求。
-
Java无法直接用do-while实现非阻塞I/O轮询通讯,因JVM缺乏对UART/I²C/BLE等外设的原生非阻塞支持;do-while仅用于带退出条件的有限重试或数据拼包,真正的低功耗需依赖中断、回调或底层epoll/poll机制。
-
Java类加载机制分加载、链接(含准备)、初始化三阶段:加载时仅载入字节码并生成Class对象,静态变量未分配内存;准备阶段为其分配内存并设默认零值;初始化阶段执行<clinit>方法,按源码顺序赋值静态变量和执行静态块。
-
GZIPOutputStream用于网络传输前动态压缩数据流,需正确包装、调用finish()、确保接收端支持解压;适合文本等高冗余数据,对JPEG等已压缩格式无效;HTTP需设Content-Encoding:gzip,Socket需双方约定协议。
-
Java静态初始化严格按源码顺序执行且仅一次;若某静态字段初始化触发其他类加载,原类未完成初始化的字段仍为默认值,易致空指针。
-
正向预查((?=...))匹配位置而非内容,要求该位置后紧接指定模式但不消耗字符;如\d+(?=px)只匹配数字部分,不包含px。