-
对象生命周期管理应通过构造方法、AutoCloseable接口、try-with-resources语句及框架注解实现;优先使用try-with-resources确保资源及时释放,避免finalize,推荐静态工厂方法和依赖注入提升可维护性。
-
synchronizedMap通过包装非线程安全Map实现单操作线程安全,但复合操作需手动加锁,遍历时必须显式同步,且因全局锁性能较低,高并发应选用ConcurrentHashMap。
-
Java对象序列化依赖java.io.Serializable标记接口,JVM通过ObjectOutputStream.writeObject()检查该接口并默认序列化非transient非static字段;需显式声明serialVersionUID保障版本兼容,transient和static字段因安全或语义原因不参与默认序列化;现代项目更推荐JSON、Protobuf等跨语言方案。
-
volatile仅保证可见性、禁止指令重排序和happens-before关系,不保证原子性;如count++因读-改-写非原子仍线程不安全,适用状态标志、一次性发布等场景,复杂操作需synchronized或原子类。
-
Java8允许接口定义默认和静态方法。1.默认方法用default修饰,可提供实现且不强制子类重写,支持接口演进与多继承行为;2.静态方法用static修饰,通过接口名调用,用于工具函数;3.类实现多个含相同默认方法的接口时需显式重写以解决冲突;4.默认方法可被重写并能访问抽象方法,静态方法不可重写也不能访问实例成员。这一改进使接口更具扩展性,便于集合框架等大型API升级,同时促进函数式编程支持,提升代码复用与维护性。
-
多态不是语法糖,是运行时通过虚方法表动态绑定:编译看引用类型,运行看实际对象类型;static方法、字段、private/final方法不参与动态绑定。
-
Java变量定义须满足类型明确、命名合规、作用域清晰、初始化充分四点要求:必须显式声明类型;变量名符合标识符规则并推荐小驼峰命名;成员变量有默认值,局部变量须显式初始化;禁止不安全的隐式类型转换和非法引用赋值。
-
Java只有值传递,传递对象时实际是引用的副本,副本与原引用指向同一对象,因此可修改对象状态但无法改变原引用本身。
-
BigInteger用于处理超大整数,位于java.math包,需通过字符串或数组创建,支持高精度运算,适用于密码学等领域。
-
锁粗化是JVM由JIT编译器在热点代码编译阶段自动触发的优化,将同一锁对象、同一线程连续执行、无共享状态干扰的多次相邻加锁/解锁合并为一次更大范围加锁。
-
HashMap与Hashtable的核心区别在于时代背景与设计哲学:前者是JDK1.2集合框架下的现代标准实现,支持泛型、null键值、非同步及红黑树优化;后者是JDK1.0遗留类,继承Dictionary、拒绝null、全表同步且无后续演进。
-
Log4j与SLF4J是分层协作关系:SLF4J为日志门面API,Log4j2为实现;需通过log4j-slf4j2-impl绑定,排除旧版冲突包,并正确配置log4j2.yaml等文件于resources下。
-
里氏替换原则要求子类能替换父类且不改变程序正确性,文中以图形面积计算为例,指出Square继承Rectangle会导致行为不一致,违反LSP;改进方案是让Rectangle和Square均继承自抽象类Shape,各自独立实现getArea方法,确保行为契约一致,从而符合LSP。
-
Java地址簿管理需设计Contact实体类(含name、phone、email、address、id字段及equals/hashCode/toString)和AddressBook管理类(用ArrayList或HashMap存储,提供增删改查方法),支持文件持久化(序列化或JSON)与命令行交互。
-
必须实现Comparable接口时:类需支持Arrays.sort()、Collections.sort()或作为TreeSet/TreeMap的key;一个类仅能有一种自然顺序;第三方final类无法修改源码,故不可通过实现Comparable改变其排序逻辑。