-
关系运算符(>、<、==、!=)比较两值返回True或False;数字按大小、字符串按Unicode码点、列表按元素顺序比较;==判等,=赋值;结果可用于条件判断或变量存储。
-
CyclicBarrier适用于多阶段并行计算,支持重复使用,每轮等待所有线程到达后自动重置;CountDownLatch不可重用,频繁新建实例会增加开销和出错风险。
-
G1通过Region机制规避外部碎片:每个Region为独立分配单元,无需物理连续空间;回收以Region为粒度采用复制算法,仅Humongous对象需连续空间,碎片风险被限制在可控范围内。
-
ArrayIndexOutOfBoundsException发生在访问超出数组范围的索引时,如长度为5的数组访问索引5;常见于循环边界错误或输入验证缺失,需通过合理逻辑控制和异常处理提升程序健壮性。
-
Java中使用IDN.toASCII()将中文域名转Punycode,需确保输入为纯域名标签、先trim()和NFKC标准化、捕获IllegalArgumentException异常,转换结果如“xn--4gq15d.com”可直接用于DNS解析。
-
String.intern()适用于低基数、高重复、长生命周期字符串(如日志状态、配置key、JSON字段名),可省内存、提==判断速度;但须赋值接收返回值,禁用于动态拼接、敏感信息和超长字符串,且需配合JVM参数调优。
-
死锁典型场景是线程间嵌套加锁顺序不一致;应按对象哈希值升序加锁、避免锁内调用外部方法、缩小同步范围;推荐用ReentrantLock.tryLock()超时机制规避;jstack和ThreadMXBean可检测死锁;LockSupport.park/unpark误用亦致逻辑死锁;根本解法是消除共享可变状态。
-
CountDownLatch的await()阻塞在AQS共享队列中,因tryAcquireShared返回-1导致线程入队并park;countDown()通过CAS循环确保state递减原子性;其不可重置源于state归零后拒绝修改,而CyclicBarrier基于可重置的count和Condition实现。
-
List.copyOf不能替代newArrayList(list),因为它返回不可修改的浅拷贝视图,不支持增删操作,不隔离原列表变更,也不防御元素内部状态被修改。
-
因为JVM的tableswitch和lookupswitch指令要求跳转目标在类加载时确定,故case必须是编译期常量;否则编译报错“constantexpressionrequired”,不退化为if-else。
-
String.equalsIgnoreCase()是处理用户名大小写比对最直接安全的方式,它基于Unicode值逐字符比较、不依赖本地化规则、不创建新对象,但调用方不可为null,需先判空;推荐结合trim()和非空检查使用。
-
应使用NumberFormat.getNumberInstance()静态工厂方法获取本地化数字格式器,它基于默认Locale自动适配千分位与小数分隔符;显式传入Locale(如Locale.CHINA)可确保格式可控;避免硬编码DecimalFormat模式。
-
双重检查锁定在Java中失效是因为JVM指令重排序与引用可见性未同步,导致线程可能看到未完全初始化的instance;必须用volatile修饰instance字段以建立happens-before关系。
-
使用Collectors.toMap时,应在keyMapper中直接格式化key(如转小写、去空格等),遇重复key需提供mergeFunction避免异常,复杂逻辑应封装为工具方法提升可读性。
-
TextBlock默认压缩换行符为单空格,需显式设xml:space="preserve"或替换换行符;JSON错位多因BOM/零宽字符,应提前过滤;高亮需拼Run或换AvalonEdit;大SQL卡顿源于TwoWay绑定,应改OneWay并优化数据源。