-
答案:通过null检查、Objects.requireNonNull、Optional封装和注解分析可有效避免NullPointerException。在调用方法或访问字段前进行防御性判断,使用Objects工具校验参数,采用Optional减少null返回,结合@NonNull等注解配合静态工具提前预警,养成良好编码习惯以提升代码健壮性。
-
初学者应先用ArrayList和Scanner实现图书借阅核心流程,定义Book(含isbn、title、author、isBorrowed)和BorrowRecord(含bookIsbn、borrowerName、borrowDate)两个类,用for循环处理借书逻辑,注意Scanner.nextLine()前需调用scanner.nextLine()清除换行符,并用文本文件保存数据。
-
根本原因是泛型擦除导致类型信息丢失且实际元素不满足Comparable合约;例如List<Object>混存Integer和String时编译通过但运行抛ClassCastException。
-
Java项目在Eclipse中需三处统一设为UTF-8:项目级Textfileencoding(右键项目→Properties→Resource)、工作空间全局编码(Window→Preferences→Workspace)、Maven的project.build.sourceEncoding;否则中文注释、文件读写、编译均可能乱码。
-
静态导入是Java5引入的特性,用于直接导入类的静态成员以省略类名前缀;支持导入指定成员或通配符导入所有静态成员,但后者易引发命名冲突;适用于单元测试、数学计算和集合工具操作等场景,需避免滥用影响可维护性。
-
super是编译期确定的直接父类成员访问入口,不触发多态、不绕过访问控制;调用构造器须首行且唯一;访问字段和方法均为静态绑定;内部类中A.super特指外围类方法调用。
-
corePoolSize和maximumPoolSize应依任务类型设定:IO密集型用公式计算,CPU密集型≈CPU核数;maximumPoolSize仅在有界队列下有效,LinkedBlockingQueue默认无界致其失效;keepAliveTime建议60秒,过短增调度压力,过长占资源;拒绝策略应自定义日志告警而非直接使用JDK默认策略。
-
HttpClient.SendAsync不会阻塞线程,它基于异步I/O机制实现;但误用.Wait()或.Result会导致死锁。应始终await调用,复用HttpClient实例推荐使用IHttpClientFactory,响应读取需在作用域内完成,超时与重试需协同配置。
-
JavaEndorsed机制仅替换JDK6–8中java.和javax.下标准扩展类(如jaxb-api.jar),通过-Djava.endorsed.dirs指定目录优先加载,JDK9+已彻底移除;升级至JDK11+需显式添加JakartaEE依赖并处理包名迁移。
-
Lambda只能访问effectivelyfinal变量,因编译后会捕获局部变量的副本,为避免数据不一致,要求变量初始化后不可变;可访问final或未被重新赋值的局部变量、实例/静态字段、方法参数及数组引用(元素可改),但不能修改非final局部变量;可通过AtomicInteger、数组包装或终端操作绕过限制,核心是保证闭包内变量状态的一致性。
-
读写锁适用于读多写少场景,通过分离读锁(共享)和写锁(独占)降低线程争用;ReentrantReadWriteLock支持锁降级但不支持升级;性能优势依赖读写比例与临界区长度,写占比超15%~20%时可能劣于普通锁;公平模式可缓解饥饿但增加开销。
-
Java中控制对象可变性的核心是让对象状态创建后无法修改,需通过类final、字段privatefinal、防御性拷贝、避免this逃逸及合理使用不可变API等协同实现。
-
Java中try-catch用于捕获处理运行时异常,避免程序意外终止;需将可能出错代码放入try块,对应处理逻辑写在catch块,finally用于资源清理;多catch时子类异常须在父类前;JDK7+推荐try-with-resources。
-
Java中ExecutorService需通过Executors工厂方法或手动构建ThreadPoolExecutor创建;常用方式包括newFixedThreadPool(固定线程数、无界队列)、newSingleThreadExecutor(单线程串行)、newCachedThreadPool(弹性线程、SynchronousQueue)和newScheduledThreadPool(定时任务);自Java9起推荐显式构造ThreadPoolExecutor以控制参数。
-
Java不支持类的多重继承,仅允许单继承以避免菱形继承等问题,但通过接口(含default方法)、组合、委托、内部类及抽象类与接口组合等机制实现多源行为复用与灵活建模。