-
锁消除是JVM通过逃逸分析在JIT编译阶段自动移除未逃逸对象的无意义同步操作;前提是对象仅在当前线程内使用且不被外部访问,如局部StringBuffer的append调用。
-
在Java中,LinkedHashMap是HashMap的一个子类,它通过维护一个双向链表来保证元素的插入顺序。这意味着当你遍历LinkedHashMap时,元素的返回顺序与它们被插入的顺序一致。这一点与HashMap不同,HashMap不保证任何顺序。保持插入顺序的基本用法创建一个LinkedHashMap非常简单,和HashMap的使用方式几乎一样:LinkedHashMapmap=newLinkedHashMap();map.put("apple",1
-
Java文件读写核心是按场景选API:小文件用Files(需显式指定Charset),大文件用BufferedInputStream/OutputStream,文本处理须用InputStreamReader/OutputStreamWriter配Charset,异常要分级捕获。
-
ReferenceQueue是监控对象实例被回收的通知通道,入队的是WeakReference或PhantomReference等引用对象本身,而非原始对象;需构造时显式传入,通过poll()/remove()轮询确认回收完成。
-
正则表达式核心功能包括文本匹配、子串提取、文本替换、文本分割及断言与定位控制。它通过模式规则实现精准文本处理,广泛应用于验证、抽取、清洗、切分和上下文限定等场景。
-
CopyOnWriteArrayList写操作慢是因为每次add/set/remove都要复制整个底层数组,导致CPU和GC压力双升;数组大时单次add可能分配几十MB临时对象;迭代器基于快照,修改不可见且不抛ConcurrentModificationException。
-
用equals()比较字符串内容,别用==;equals()逐字符比较且安全处理null,但需非null对象调用;忽略大小写用equalsIgnoreCase();防NPE应字面量在左或用Objects.equals()。
-
应先用jstack和ps-T确认线程数暴增及OS级线程耗尽,再排查未关闭线程、第三方库泄漏及线程池配置不当(如newCachedThreadPool无界问题),而非盲目调大ulimit或-Xss。
-
强制转换不能实现归一化,仅辅助精度保留与类型适配;归一化需先识别指标属性(极大型、极小型、类别型、区间型),再选择对应方法(min-max、倒数反转、标签编码、三折线等),并在流式场景中结合分位数截断、对数压缩或Welford算法实现轻量无状态处理。
-
反射时抛出NoSuchFieldException的最常见原因90%的NoSuchFieldException都是因为字段名拼写错误,尤其是大小写不一致——Java字段名严格区分大小写,而开发者常凭印象写成userName却实际定义为username或USERNAME。反射查字段本质是字符串匹配,不会做任何“近似查找”或“驼峰容错”。哪怕只错一个字母或大小写,Class.getDeclaredField("xxx")就直接炸。检查目标类的源码或反编译结果,确认字段声明的**原始拼写
-
根本原因是手动修改集合结构导致modCount与expectedModCount不一致而抛ConcurrentModificationException;正确做法是仅通过迭代器的remove()方法删除,且必须在next()后调用一次。
-
Java类设计核心是职责分离:extends表“是什么”,implements表“能做什么”;优先组合、接口、final修饰与构造器安全,严守里氏替换原则。
-
在Java中实现线程同步的目的是确保多线程环境下共享资源的并发访问安全,避免竞态条件、数据不一致等问题。1.synchronized关键字适用于简单同步场景,通过锁定对象或类实现方法或代码块的同步,但其锁不可中断且粒度较粗;2.volatile关键字保证变量的可见性,适用于状态标志等无需原子性的场景,但不能保证复合操作的原子性;3.java.util.concurrent.locks包(如ReentrantLock)提供更灵活的锁机制,支持尝试获取锁、可中断锁、公平锁等高级特性,适用于需要细粒度控制的复杂
-
企业级缓存须分层选用引用类型:强引用仅限核心上下文,软引用用于高价值可重建热数据,弱引用用于无重建成本临时数据,并需ReferenceQueue清理幽灵引用,叠加LRU/LFU限容及监控灰度。
-
静态代码块在类加载的初始化阶段执行且仅一次,用于驱动注册、配置加载等一次性初始化;按声明顺序执行,早于构造器,线程安全,但抛异常会导致类初始化失败。