-
Java的System类不能直接加载非JNI兼容的DLL;必须使用按JNI规范编写的、导出Java_类名_方法名函数的DLL,再通过System.load()(绝对路径)或System.loadLibrary()(需配置java.library.path)加载。
-
TreeSet的Comparator必须是函数式接口实现,排序逻辑由其决定且初始化后不可变;多字段排序须用Integer.compare()等安全方法防溢出;推荐用Comparator.comparing().thenComparing()链式调用提升可读性与健壮性;自定义Comparator还直接影响contains()和remove()行为,判定相等仅依据compare(a,b)==0。
-
魔数须为4字节固定int型(如0x12345678)以区分非法连接,版本字段占1字节便于平滑升级;长度字段紧随其后且定长4字节,表示消息体字节数并校验上限;消息体首选Protobuf,避免嵌套过深,不加应用层分隔符。
-
Map.values()返回的是Collection而非List,它是底层Map的值视图,不支持随机访问和排序,修改会影响原Map,遍历时并发修改会抛ConcurrentModificationException。
-
抽象类自身不占实例内存,子类对象内存=父类非静态字段+子类字段+对象头+填充对齐;abstract关键字对对象内存零影响,决定内存大小的只有字段声明而非抽象性。
-
final用于修饰类、方法、变量和参数,表示不可变。1.final类不能被继承,如String类,确保行为不被修改;2.final方法不能被重写,保证核心逻辑不变;3.final变量只能赋值一次,基本类型值不变,引用类型地址不变;4.final参数在方法内不能被重新赋值,常用于匿名内部类和lambda表达式。合理使用可提升代码安全性和可读性,尤其在多线程环境下保障初始化安全。
-
String.replace()默认只替换第一个匹配项,如"a-b-a-b".replace("a","x")结果为"x-b-a-b";全量替换需用正则加g标志或ES2021新增的replaceAll()方法,后者专为字面量全替换设计、性能更优但不支持正则功能。
-
直接装JDK21并配好JAVA_HOME只需三步:选MSI安装包、装到纯英文无空格路径、JAVA_HOME必须指向JDK根目录而非bin;否则java-version会报错,Maven/IDEA等工具也无法识别。
-
下载Maven二进制包并解压到无中文无空格路径,配置M2_HOME和PATH环境变量,确保JDK版本匹配(Maven3.9+需JDK17+),再配置阿里云镜像加速首次构建。
-
accessOrder必须显式设为true才启用访问顺序,使get()或put()已存在key时将对应Entry移至链表尾部;默认false按插入顺序维护,LRU失效。
-
本文详细讲解如何使用JavaStreamAPI或传统循环方式,对包含多个数值字段的对象列表进行逐字段求和,并封装为单个汇总对象。
-
<p>减法比较会因整数溢出导致排序逻辑翻转,如Integer.MAX_VALUE-Integer.MIN_VALUE结果为-1;应使用Integer.compare(a,b)避免溢出,它通过条件判断返回-1/0/1,性能好且安全。</p>
-
for循环用于已知次数的重复执行,语法为for(初始化;条件;更新){循环体},示例打印1到5。
-
StreamTokenizer需手动设置ordinaryChar()识别运算符,调用parseNumbers()才能识别数字,不支持负数绑定,需自行处理负号;注释需预处理,四则运算建议改用正则或ScriptEngine。
-
ConcurrentHashMap的size()返回近似值,因采用baseCount与counterCells分片计数,遍历时不阻塞写操作,且存在扩容、CAS延迟及缓存伪共享等导致统计滞后;JDK8起推荐使用mappingCount()。