-
Integer.valueOf()在-128~127范围返回缓存实例,超范围才new;自动装箱调用valueOf,拆箱调用intValue();null调用intValue()抛NPE,需判空;缓存边界与空安全是高频陷阱。226 收藏 -
Java面向对象封装需三步协同:属性私有化(private字段)、提供受控访问(校验性getter/setter)、隐藏实现细节(方法内聚、不暴露内部状态)。225 收藏 -
Java中没有\_JavaMethodReference类,它是非标准的误传概念;方法引用是JDK8+语法特性,编译后生成函数式接口实例,运行时无法直接反射获取原始Method对象。225 收藏 -
类是模板,对象是用new创建的具体实例;类不占内存、不能执行方法,仅描述结构,真正存储数据和执行行为的是对象,每个对象拥有独立字段值,静态成员除外。225 收藏 -
线程中异常无法被直接捕获,需通过UncaughtExceptionHandler、全局处理器、Callable与Future或自定义线程工厂处理,确保异常不被忽略。225 收藏 -
HashSet判断重复需同时满足hashCode()相同且equals()返回true;仅用hashCode()会因哈希冲突导致误判;自定义类须重写二者,否则默认基于内存地址比较;底层基于HashMap实现,故支持null、不安全,且去重逻辑等同key去重。225 收藏 -
抽象类的核心作用是定义模板、约束行为、复用代码、防止误用;它提供统一结构,强制子类实现抽象方法,支持继承具体实现,并体现“概念而非实例”的设计思想。225 收藏 -
Java内存模型(JMM)确保多线程环境下的可见性、有序性和原子性,通过volatile、synchronized等机制保障线程间变量的正确交互;GC机制则自动管理内存,采用标记-清除、复制、整理等算法及分代收集策略回收无用对象,提升内存利用率。1.JMM通过Happens-Before原则定义操作顺序,确保共享变量的可见性,避免缓存不一致和指令重排带来的并发问题;2.GC机制根据应用对吞吐量或延迟的需求选择合适收集器,如Parallel追求高吞吐,CMS、G1、ZGC等适用于低延迟场景;3.排查OOM需225 收藏 -
成员变量定义在类内方法外,局部变量定义在方法、构造器或代码块内;前者有默认值、存于堆/方法区,后者须显式初始化、存于栈帧且作用域受限。225 收藏 -
构造方法中不可用try-catch吞掉checked异常,否则对象状态不一致;应抛出异常或改用静态工厂方法,确保资源安全与语义清晰。225 收藏 -
抽象类是解决共性逻辑复用与行为契约强制矛盾的核心机制;必须用abstractclass而非interface的场景包括共享状态、复用构造逻辑、提供可访问字段的默认实现及支持模板方法模式。225 收藏 -
Java标准库不支持MP3播放,因其仅内置PCM解码器;需用JLayer等第三方库解码为PCM流后通过SourceDataLine输出,并注意格式匹配、线程安全及跨平台设备适配。225 收藏 -
corePoolSize设太小会导致频繁创建线程:当提交任务时,若当前线程数小于corePoolSize,会创建新线程执行任务,而非复用空闲线程或放入队列。225 收藏 -
ConcurrentLinkedQueue.offer()返回true不保证其他线程立即可见,因依赖CAS和volatile而非全量内存屏障;poll()返回null不表示队列空,可能是竞态导致的临时不一致;size()为O(n)且不可靠,应避免用于流程控制。225 收藏 -
Java的垃圾回收通过标记-清除、复制、标记-整理算法实现自动内存管理,分代回收结合三者优势,提升性能。225 收藏