-
printStackTrace()可快速输出完整堆栈到System.err,适用于开发调试;需判空避免NPE;获取字符串应使用StringWriter+PrintWriter;日志中须传Throwable实例而非字符串拼接。
-
变量遮蔽指子类或方法内同名变量覆盖父类/成员变量,需用this访问当前对象成员、super访问父类成员;构造器中this()和super()须首行且互斥;遮蔽是静态绑定,不同于方法重写的动态绑定。
-
Java7+支持单个catch捕获多种互不继承的异常,用|分隔,共享最小公共父类变量;被抑制异常需通过getSuppressed()获取;Java6需用instanceof或多个catch块替代。
-
接口定义行为契约,抽象类提供共用实现。通过接口实现多继承行为,定义“能做什么”;抽象类封装共有属性与方法,解决“是什么”和“如何部分实现”。典型模式如List与AbstractList,接口规范标准操作,抽象类实现通用逻辑,开发者可选择完全自定义或继承抽象类重写必要方法,兼顾扩展性与复用性。
-
Function本质是类型安全的映射函数,具泛型约束、可实例化传递组合,核心为无副作用的apply(T)→R纯转换。
-
G1的RSet只记录老年代→年轻代引用,因年轻代对象生命周期短,其引用老年代对象不影响后者的存活判定;而年轻代回收需避免扫描全老年代,故必须记录反向引用以保障安全回收。
-
必须用volatile修饰静态实例变量,否则多线程下可能拿到未初始化完成的对象;因为JVM创建对象的三步(分配内存、调用构造函数、赋值引用)可能重排序,导致其他线程看到半初始化状态。
-
Java提供三种注释:单行注释//用于简要说明,多行注释/.../用于多行或禁用代码,文档注释/*.../生成API文档,合理使用可提升代码可读性与维护性。
-
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()方法,后者专为字面量全替换设计、性能更优但不支持正则功能。