-
Java中线程分为用户线程和守护线程,主要区别在于JVM退出机制:1.用户线程会阻止JVM退出,只要存在用户线程运行,JVM就继续执行;2.守护线程不阻止JVM退出,当所有用户线程结束后,即使守护线程仍在运行,JVM也会终止;3.新线程默认为用户线程,可通过setDaemon(true)设为守护线程,但必须在start()前调用;4.主线程是用户线程,子线程继承父线程的daemon状态;5.典型场景:用户线程处理业务逻辑,守护线程用于日志监听、资源监控等后台服务任务。
-
Files.lines()流式读取大文件更简洁且默认UTF-8,但须try-with-resources防句柄泄漏;需处理编码探测、NUL截断、大小写匹配、滑动窗口上下文、正则预编译、行号控制及高亮安全替换。
-
extends是Java中声明单继承的唯一关键字,格式为class子类名extends父类名,父类不能是final或非public(跨包时),不可多继承,子类继承public/protected成员,构造器需显式调用super(参数)若父类无无参构造。
-
通过抽象类定义共通行为,如Animal的makeSound;利用接口实现多维能力,如Flyable;结合策略模式动态切换行为,提升灵活性。
-
优先用Introspector读POJO属性:它自动过滤静态/合成/桥接方法,兼容isXxx()/getXxx(),但要求类遵循JavaBean规范;getDeclaredField适合绕过封装,需手动处理访问控制、继承及模块限制,且必须判空readMethod并缓存PropertyDescriptor。
-
Java分批应优先用subList或GuavaLists.partition,避免Stream.collect硬凑;需注意视图修改风险、空值校验及并发安全。
-
CopyOnWriteArrayList写操作不阻塞读,因每次修改都新建数组复制内容,读操作持老数组引用且无锁;但写开销大、迭代器不可见新元素、多方法组合非原子。
-
桥接模式通过分离抽象与实现,使两者独立变化,适用于多维度扩展场景。如图形系统中形状与渲染方式、日志系统的输出目标、支付方式与渠道、跨平台GUI绘制等,均可用此模式避免类爆炸,提升灵活性。核心是识别独立变化的维度,用组合代替继承,动态切换实现,降低耦合。但需避免过度设计,仅在多维度独立演化时引入。
-
不能。finally块仅保证执行,不自动关闭资源;需手动在其中用try-catch分别关闭各资源并判空,避免异常中断清理;Java7+推荐try-with-resources,但老代码仍依赖正确编写的finally。
-
构造方法重载必须满足:同一类中方法名相同(即类名)、参数列表不同(数量、类型或顺序至少一者不同)、与访问修饰符和返回值无关;本质是通过签名差异实现编译期唯一绑定。
-
逻辑运算符&&和||支持短路特性,即一旦结果确定便不再执行后续条件;例如,当obj为null时,obj!=null&&obj.getValue()>10不会触发空指针异常,因前半为false后半被跳过;同理,isAdmin||hasPermission()中若isAdmin为true,则不调用hasPermission();而非短路运算符&和|会始终执行所有部分,适用于需强制副作用的场景,但常规判断中推荐使用短路形式以提升安全与效率。
-
集合框架比数组更灵活可扩展,但需依场景选择:动态扩容、类型安全、内置算法和对象操作选集合;固定长度、高性能读取、低内存开销选数组。
-
InterruptedException是线程被主动中断时抛出的检查异常,必须显式处理;它仅在调用特定阻塞方法且线程已被interrupt()时触发,本质是设置中断状态位并在阻塞点抛异常,而非强制终止线程。
-
Java集合框架提供统一、可扩展、类型安全的容器接口与实现,解决数组长度固定、缺乏内置算法等问题,支持动态扩容、泛型约束、统一操作契约及并发安全等特性。
-
final修饰变量、方法、类分别实现引用/值不可变、禁止重写、禁止继承;但final仅是不可变性的必要条件,非充分条件,需配合private、无修改方法、防御性拷贝等才能实现真正不可变。