-
EnumMap比HashMap存枚举更快,因其用数组实现,索引由枚举ordinal()直接决定,省去hash计算、寻址、扩容及树化等开销,且内存局部性好、分支预测友好。
-
Math.ceil()用于向上取整,正确计算分页总数:inttotalPages=(int)Math.ceil((double)totalCount/pageSize),需确保除法为double类型且pageSize>0。
-
Spring三级缓存不解决构造器注入循环依赖,因其要求实例化时即获得完整依赖对象,无法提前暴露半成品;仅支持单例Bean的字段或setter注入,通过singletonFactories→earlySingletonObjects→singletonObjects严格时序协作实现解耦。
-
List.of()返回真正不可变列表,所有修改操作均抛UnsupportedOperationException,且禁止null;Arrays.asList()返回数组视图,支持set修改元素但不支持add/remove,允许null。
-
String.join比StringBuilder更适合简单拼接,因其语义清晰、代码简洁、自动处理空集合返回"",但不跳过null或空字符串,仅适用于纯字符串+固定分隔符场景。
-
要让RMI远程调用支持对象变量作为参数传递,核心是序列化机制的正确应用。JavaRMI本身不直接传输对象实例,而是把对象状态(字段值)序列化成字节流,经网络传到服务端后反序列化重建对象。这个过程对开发者透明,但必须满足严格条件,否则会抛出NotSerializableException或运行时失败。对象类必须实现Serializable接口这是最基本也是最关键的一步。只有显式声明implementsSerializable的类,JVM才允许对其序列化:接口本身无方法,仅作标
-
类是对象的模板,定义属性和方法;对象是类的实例,通过new创建并独立存储数据;构造方法初始化对象,访问修饰符控制成员可见性,实现封装。
-
用PriorityQueue求TopK比排序快,因时间复杂度为O(nlogk)而非O(nlogn);需控制堆大小≤K,新元素大于堆顶才offer并poll;取结果必须poll才能有序,toArray等方法不保证顺序。
-
Java中native方法抛异常需通过JNI函数显式注册,如ThrowNew;抛出后须立即返回且不可ClearException,否则Java层无法捕获或导致JVM崩溃。
-
volatile写操作通过StoreLoad屏障强制刷回主内存并使其他缓存失效,读操作通过LoadLoad+LoadStore屏障强制从主内存加载最新值,但不保证复合操作原子性。
-
正则删除重复标题行需先精准匹配标题特征(如^#{1,2}\s+.+$),再用反向引用保留首个并清除后续相邻重复;非相邻重复须借助Python等脚本配合set去重,操作前务必备份并测试。
-
newInteger(127)==newInteger(127)为false,因为new总是创建堆中独立对象,==比较的是内存地址而非值,即使数值相同、在缓存范围内,也绝不复用对象。
-
URL构造函数最可靠,但search参数需注意:search返回编码态字符串,searchParams.get()自动解码;pathname末尾斜杠影响值,拼接子路径应使用newURL('detail',url).pathname;searchParams不暴露原始编码,IE需降级。
-
要通过NIO.2的WatchService实时监听文件系统事件,需正确注册路径、解析WatchEvent类型与context相对路径并resolve为绝对路径,注意单层监听、跨文件系统限制、事件丢失及MODIFY语义模糊等问题。
-
ArrayList.remove(intindex)删除非末尾元素时,内部在fastRemove()中调用一次System.arraycopy,将elementData[index+1]至末尾元素前移一位,覆盖被删位置,不缩容数组长度。