-
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适合读多写少场景,通过写时复制实现线程安全,读无锁但写开销大、内存占用高,不支持迭代中删除,仅提供最终一致性。
-
遍历集合时须用迭代器remove()或removeIf()安全删除,禁用collection.remove();并发场景需选CopyOnWriteArrayList或加锁;for-each或正序for循环中直接remove会引发ConcurrentModificationException或漏删。
-
DatagramSocket是JDK原生UDP最小可用单元,轻量低延迟,但线程不安全;需防端口占用、缓冲区溢出、编码不一致;connect()仅作地址过滤;高并发应选DatagramChannel或Netty。
-
非静态内部类默认持有外部类强引用,Java编译器在字节码中注入this$0字段,导致Activity等组件无法被GC回收,引发内存泄漏;Handler、匿名监听器及捕获实例方法的Lambda均属此类。
-
本文介绍在Java中将float数组(如[1.0f,0.95f,0.11f])简洁、高效地转换为逗号连接字符串(如"1.0,0.95,0.11")的多种方法,重点推荐基于IntStream的函数式写法,并对比传统循环与第三方库方案。
-
LinkedHashSet继承HashSet并保持插入顺序,适用于去重且需顺序的场景。1.创建时可指定初始容量;2.add()添加元素,自动去重;3.遍历时按插入顺序输出;4.支持remove()、contains()等操作;5.常用于关键词去重、缓存等。注意:允许null、非线程安全。
-
通过@ControllerAdvice和@ExceptionHandler实现全局异常处理,结合自定义BusinessException与统一ErrorResponse格式,提升代码可维护性与用户体验。1.定义GlobalExceptionHandler类捕获NullPointerException、IllegalArgumentException及自定义异常;2.BusinessException包含code与message便于前端识别;3.所有异常返回标准JSON结构;4.异常处理按类型匹配,具体异常
-
Java进程是资源分配的基本单位,拥有独立内存空间;线程是CPU调度的基本单位,共享进程内存但独享栈空间;一个进程至少含一个主线程,线程不能脱离进程存在。