-
自旋锁不能直接用while(true)因会吃满CPU且无内存可见性保障,需用volatile或AtomicReference等保证happens-before;应避免手写普通布尔变量循环,推荐AtomicReference/Integer表示状态,解锁用set()或lazySet()而非compareAndSet()。
-
Enum.valueOf严格匹配枚举常量名(区分大小写、不可含空格),需封装安全转换逻辑,如忽略大小写、trim空格、提供默认值或使用枚举内建fromString方法。
-
ThreadLocal不是线程私有变量的自动托管工具,而是以线程为维度的Map查找机制;真正隔离靠每个线程独立持有ThreadLocalMap实例,staticfinal声明仅共享ThreadLocal对象本身,各线程操作的是各自Thread.threadLocals中的值。
-
Java字符串常量池调优需根据实际intern字符串数量和冲突率合理设置-XX:StringTableSize,目标是平均桶长≤1.5,优先验证是否真需调整,避免盲目增大导致内存浪费。
-
Java中long和float字面量需加L/F后缀,因整数默认int、浮点数默认double;如10000000000无L会超int范围报错,3.14无F因double转float隐式降级被禁止。
-
硬编码魔法值在分支结构中危害严重,应通过语义化封装、规则外置化、策略模式和快照日志实现可配置、可审计的规则体系,并渐进式落地。
-
关键在识别哪一层悄悄拆箱,而非定位报错行;三元运算、Stream.collect、算术表达式及方法赋值时易因包装类null触发隐式拆箱NPE,需统一用Optional、Objects工具或注解防控。
-
JNI开发的核心在于通过一套标准流程实现Java与C/C++的交互。具体步骤为:1.在Java中声明native方法并加载本地库;2.使用javac生成JNI头文件;3.根据头文件实现C/C++代码;4.编译生成动态链接库;5.运行Java程序并确保库路径正确。JNIEnv指针是JNI操作的关键,它提供与JVM交互的函数接口,且具有线程局部性。数据类型转换方面,基本类型较简单,字符串需注意GetStringUTFChars后必须调用ReleaseStringUTFChars释放内存,数组操作类似,对象访问
-
“锁死方法引用边界”非标准术语,真实影响压测平滑性的是流量模型、依赖隔离、自适应限流策略、JVM预热及数据源瓶颈;应通过RPS线性加压、关闭动态熔断、Mock下游、服务预热等确定性手段实现平滑压测。
-
G1字符串去重由-XX:+UseStringDeduplication实现,仅作用于老年代中内容相同的byte[]/char[],StringTable不参与去重;jcmdVM.stringtable仅显示intern引用元信息,无法反映去重效果,需通过PrintStringDeduplicationStatistics日志确认。
-
根据使用场景选择Java集合类型:若需有序且可重复,选ArrayList(读多写少)或LinkedList(频繁增删);去重选HashSet(无序)、LinkedHashSet(保持插入顺序)或TreeSet(排序);键值对存储用HashMap(常用)、LinkedHashMap(顺序访问)或TreeMap(按键排序);多线程环境优先选用ConcurrentHashMap或CopyOnWriteArrayList以保证线程安全。
-
答案:Java中字符串拼接应根据场景选择方法:简单拼接用+,编译时会优化为StringBuilder;循环中用StringBuilder提升性能;集合拼接用String.join()更简洁;格式化用String.format()或formatted()。
-
二叉树的深度和高度定义方向相反:深度从根向下数边数,高度从节点向上到叶数边数;整棵树二者数值相等,但节点级含义不同。
-
本文详解hasNextInt()的工作原理与典型误用场景,重点演示如何用它替代try-catch实现健壮的双整数输入验证,并给出可复用的循环输入处理方案。
-
Selector通过操作系统内核的I/O多路复用(如Linuxepoll)实现高效轮询,select()阻塞等待内核通知就绪Channel,仅处理selectedKeys()中的活跃事件,避免遍历全部Channel;注册前须设为非阻塞并指定interestOps;迭代selectedKeys()后必须手动remove();单Selector瓶颈在JVM内存、GC和业务逻辑耗时,应分离IO与业务处理。