-
线程中异常无法被直接捕获,需通过UncaughtExceptionHandler、全局处理器、Callable与Future或自定义线程工厂处理,确保异常不被忽略。
-
HashSet判断重复需同时满足hashCode()相同且equals()返回true;仅用hashCode()会因哈希冲突导致误判;自定义类须重写二者,否则默认基于内存地址比较;底层基于HashMap实现,故支持null、不安全,且去重逻辑等同key去重。
-
抽象类的核心作用是定义模板、约束行为、复用代码、防止误用;它提供统一结构,强制子类实现抽象方法,支持继承具体实现,并体现“概念而非实例”的设计思想。
-
Java内存模型(JMM)确保多线程环境下的可见性、有序性和原子性,通过volatile、synchronized等机制保障线程间变量的正确交互;GC机制则自动管理内存,采用标记-清除、复制、整理等算法及分代收集策略回收无用对象,提升内存利用率。1.JMM通过Happens-Before原则定义操作顺序,确保共享变量的可见性,避免缓存不一致和指令重排带来的并发问题;2.GC机制根据应用对吞吐量或延迟的需求选择合适收集器,如Parallel追求高吞吐,CMS、G1、ZGC等适用于低延迟场景;3.排查OOM需
-
成员变量定义在类内方法外,局部变量定义在方法、构造器或代码块内;前者有默认值、存于堆/方法区,后者须显式初始化、存于栈帧且作用域受限。
-
构造方法中不可用try-catch吞掉checked异常,否则对象状态不一致;应抛出异常或改用静态工厂方法,确保资源安全与语义清晰。
-
抽象类是解决共性逻辑复用与行为契约强制矛盾的核心机制;必须用abstractclass而非interface的场景包括共享状态、复用构造逻辑、提供可访问字段的默认实现及支持模板方法模式。
-
Java标准库不支持MP3播放,因其仅内置PCM解码器;需用JLayer等第三方库解码为PCM流后通过SourceDataLine输出,并注意格式匹配、线程安全及跨平台设备适配。
-
corePoolSize设太小会导致频繁创建线程:当提交任务时,若当前线程数小于corePoolSize,会创建新线程执行任务,而非复用空闲线程或放入队列。
-
ConcurrentLinkedQueue.offer()返回true不保证其他线程立即可见,因依赖CAS和volatile而非全量内存屏障;poll()返回null不表示队列空,可能是竞态导致的临时不一致;size()为O(n)且不可靠,应避免用于流程控制。
-
Java的垃圾回收通过标记-清除、复制、标记-整理算法实现自动内存管理,分代回收结合三者优势,提升性能。
-
静态工具类用于封装无状态的通用功能,如日期处理、字符串操作等,通过私有构造函数防止实例化,方法直接通过类名调用,提升复用性和可读性;应遵循命名清晰、参数校验、无副作用等原则,并按功能拆分工具类,避免过度集中,同时注意测试困难和共享变量的线程安全问题。
-
答案:Java实现投票统计需设计Candidate类记录选项与票数,VotingSystem管理候选人并控制投票去重,通过Map存储候选者、Set记录已投票用户,提供投票、统计和查询最高票功能,示例展示添加候选人、用户投票及结果输出流程。
-
ThreadLocal通过为每个线程提供独立变量副本实现线程隔离,其值存储于线程的ThreadLocalMap中,键为ThreadLocal实例,避免并发冲突。
-
ArrayStoreException在Java中发生时,通常是因为尝试将类型不兼容的元素存入数组中。这个问题主要出现在运行时,尤其是处理多态数组或泛型擦除相关操作时。理解ArrayStoreException当一个数组被创建为某种特定引用类型(如String[]),JVM会强制检查所有存入该数组的对象是否是该类型的实例或其子类。如果违反这一规则,就会抛出ArrayStoreException。例如,把一个Integer对象放入声明为String[]的数组中:String[]str