-
ThreadLocal通过为每个线程提供独立的变量副本来实现线程隔离,其底层依赖Thread类中的ThreadLocalMap,该Map以ThreadLocal为键(弱引用)、变量副本为值(强引用)存储数据,从而保证线程间数据独立;但由于值为强引用,当ThreadLocal被回收后若未主动清理,仍可能因Entry的key为null而value无法回收,导致内存泄漏;因此必须在使用完毕后调用remove()方法清除,尤其在线程池场景中更为关键,避免残留数据引发内存泄漏或业务错误。
-
在Java中,同一try块不能重复捕获相同异常类型,否则编译失败;应合并处理逻辑或按子类型区分,使用多异常捕获语法(如IOException|SQLException)可简化代码并避免重复;同时需遵循“先具体后一般”原则,确保子类异常在父类前被捕获,防止出现不可达的catch块。
-
封装通过private修饰字段并提供getter/setter方法,保护数据安全、提升可维护性,防止外部直接访问,并支持校验、扩展与副本返回,增强类的健壮性与灵活性。
-
WeakHashMap使用弱引用保存键,当键无外部强引用时可被GC回收,适用于缓存等易导致内存泄漏的场景。其值仍为强引用,需注意避免反向引用造成泄漏。与HashMap类似,但性能略低,因每次访问可能触发无效Entry清理。常用于GUI组件映射、附加元数据、弱监听器等场景,是标准库中开箱即用的弱引用Map实现。
-
类初始化顺序为:先静态后实例,先父类后子类。具体为:父类静态变量与静态代码块→子类静态变量与静态代码块→父类实例变量与非静态代码块→父类构造函数→子类实例变量与非静态代码块→子类构造函数,确保父类完全初始化后再初始化子类。
-
答案:在JavaGUI编程中,Swing和JavaFX的UI更新必须在专用线程(如EDT或JavaFXApplicationThread)中执行,直接在普通线程修改UI会导致线程安全问题;应使用SwingUtilities.invokeLater()或SwingWorker等机制确保UI操作在正确线程执行,从而避免界面卡顿、异常或数据不一致。
-
通过面向接口编程和依赖注入,将具体实现解耦,OrderProcessor依赖NotificationService接口而非具体类,新增SMSNotification等实现无需修改原有代码,提升可维护性与扩展性。
-
在Java中发送包含HTML内容的邮件,需正确设置MIME类型、处理字符编码、管理图片与样式,并防范安全风险。1.使用JavaMailAPI,创建MimeMessage和MimeMultipart对象,将HTML内容封装为MimeBodyPart并指定text/html;charset=UTF-8;2.嵌入内联图片时,使用Content-ID并在HTML中通过cid引用,附件则设置Disposition为ATTACHMENT;3.字符编码应统一为UTF-8以避免乱码;4.样式兼容方面采用内联CSS、表格布
-
AtomicReference提供线程安全的对象引用原子操作,支持无锁更新;其核心方法包括get、set、compareAndSet和getAndSet,适用于多线程环境下共享引用的高效管理。
-
Collections.nCopies返回不可变列表,仅存储一个元素引用以节省内存,适用于创建重复元素的固定视图,如测试数据、默认值初始化或流操作,但不支持增删改操作。
-
答案:Java中对象比较需区分引用比较(==)与内容比较(equals)。==判断是否指向同一实例,受缓存机制影响;equals比较逻辑内容,需类正确重写equals和hashCode方法以保证一致性。使用Objects.equals可安全处理null值。自定义类必须同时重写equals与hashCode,确保在集合中的正确行为。明确比较意图是关键。
-
使用ConcurrentHashMap、Future+Callable、ReadWriteLock或Caffeine等方案可实现Java线程安全缓存。1.ConcurrentHashMap适用于高并发读写场景,通过分段锁或CAS保证线程安全;2.Future方案结合原子操作避免多线程重复计算,提升性能;3.ReadWriteLock提供读写锁分离,适用于强一致性要求的批量更新;4.推荐使用Caffeine或GuavaCache等成熟库,内置线程安全与自动加载机制,简化开发。核心是避免竞态条件并控制读写互斥
-
操作日志与链路追踪需共享统一RequestContext以保障审计合规与故障定位;该上下文含traceId、spanId、userId等字段,基于ThreadLocal+不可变设计,通过Filter/Interceptor初始化,并在异步、RPC、MQ等场景显式透传。
-
FileLock是Java中基于操作系统实现的进程级文件锁,用于多进程间协调文件访问,分为排他锁和共享锁,需通过FileChannel获取,属建议性锁且不保证JVM内线程安全。
-
synchronized通过实例锁、类锁和代码块锁实现线程同步,确保共享资源安全访问。1.修饰实例方法时锁当前对象(this),不同实例互不影响;2.修饰静态方法时锁类Class对象,所有实例共用同一把锁;3.synchronized代码块可指定锁对象,提升并发性能;4.具有可重入性,JVM自动释放锁,建议使用privatefinal对象作为锁,避免使用String常量或null。正确理解锁对象和粒度是关键。