-
GuavaCache不使用软引用,其淘汰机制基于自定义LRU、权重和过期时间,与JVM引用队列无关;Caffeine仅在weakKeys()/weakValues()中可选使用弱引用,用于解决特定内存泄漏问题。
-
应预设HashMap初始容量为大于预估数量的最小2的幂(如800选1024),合理调整负载因子(默认0.75,读多可调高至0.9,内存敏感可略降),避免循环中未预分配容量导致频繁扩容,并确保key的hashCode分布均匀且稳定。
-
不可变对象因状态不可变而天然线程安全,需满足类为final、字段私有且final、无修改方法、构造无this逃逸、可变组件深拷贝等条件,如Person示例所示,其广泛应用在高并发场景中。
-
构造方法可以且必须重载以支持不同初始化场景;需参数列表不同,调用用this()且须首行,禁循环调用,无显式构造时才有默认无参构造,不可返回值但可return提前退出。
-
在Java中,使用Comparator.comparing结合thenComparing可实现多字段排序,如按name升序再按age升序:people.sort(Comparator.comparing(Person::getName).thenComparing(Person::getAge))。
-
首先安装配置JDK、Maven和Tomcat,设置环境变量并验证;接着用Maven创建Web项目模板,添加Servlet依赖和Tomcat插件;最后通过mvntomcat7:run启动应用,确保端口未占用且环境变量正确。
-
单例模式通过私有构造函数、静态实例和公共获取方法确保类唯一实例;双重检查锁定利用volatile和两次判空检查实现线程安全的懒加载,既提升性能又防止指令重排序导致的不完整实例问题。
-
Java并发集合通过分段锁、CAS、不可变快照等机制实现线程安全与高性能,支持原子复合操作,适配不同读写场景,但不保证跨操作业务逻辑的原子性。
-
::是Java中将方法或构造器适配为函数式接口实例的编译期机制,依赖目标接口签名进行类型推导,而非语法糖。
-
Java中创建接口实现类需用implements关键字并重写所有抽象方法;接口用interface声明,含常量和抽象方法;实现类可多实现,支持多态;Java8起接口可含default和static方法。
-
方法重载匹配发生在编译期,依据编译时参数类型、数量和顺序确定调用版本,遵循三阶段规则:先精确匹配与基本类型提升,再装箱/拆箱,最后可变参数;null值易致歧义,泛型重载需避免擦除后签名冲突。
-
先捕获子类再父类,确保异常处理有序。应优先捕获FileNotFoundException,再处理其他IOException,避免编译错误;可结合try-with-resources自动关闭资源,提升代码安全性与可读性。
-
单例模式在Java中用于确保一个类只有一个实例并提供全局访问点,适用于控制资源创建与访问,如数据库连接池、配置管理器等。其核心优势在于避免资源浪费和保证状态一致性,但滥用会导致代码耦合度高、测试困难。实现方式包括:1.基础懒加载实现,线程不安全;2.加synchronized关键字实现线程安全但性能较差;3.双重检查锁定,需加volatile避免指令重排序,兼顾性能与安全;4.静态内部类实现,推荐使用,线程安全且支持懒加载;5.枚举方式,简洁可靠,防止反射与反序列化破坏单例。实际开发中需注意:Spring
-
答案:Java枚举可通过定义抽象方法使各常量实现不同行为,如Operation枚举中ADD、SUBTRACT等分别实现apply方法,调用时直接通过常量执行对应逻辑,避免条件判断,提升可读性、扩展性和类型安全性,适用于状态机、策略模式等场景。
-
CopyOnWriteArrayList适合读多写少场景,通过写时复制实现线程安全,读无锁但写开销大、内存占用高,不支持迭代中删除,仅提供最终一致性。