-
不一定。多线程是否提速取决于任务可并行性、CPU密集型(宜匹配核心数)或I/O密集型(受益于并发)、并发开销(锁竞争、上下文切换)及科学基准测试,盲目使用反而更慢。
-
受检异常必须显式处理,否则编译失败;即继承Exception(非RuntimeException子类)的异常需try-catch或throws声明,如IOException;运行时异常(如NullPointerException)继承RuntimeException,编译期不检查;Error(如OutOfMemoryError)不应捕获。
-
Java泛型采用类型擦除机制,编译时移除泛型参数,运行时仅保留Object或上界类型,导致无法在运行时获取泛型信息、不能使用instanceof判断具体参数化类型、不能newT()等。
-
答案是使用方法、静态代码块、实例初始化块和工具类实现代码复用。通过方法封装逻辑可多次调用;静态块在类加载时执行一次,适合初始化静态资源;实例初始化块在创建对象时运行,用于共用初始化;公共逻辑可封装到工具类的静态方法中,便于跨类调用,提升维护性和复用性。
-
最稳妥方式是用Collection.toArray(T[])方法,传入newT[0]空数组,避免ClassCastException;因无参toArray()恒返Object[],强转String[]等会失败;原始类型数组需流式映射。
-
抽象类不必含抽象方法,其核心是限制实例化并允许部分实现;适用场景包括共享状态、构造逻辑及非public成员;设计时应明确扩展点,避免泛型擦除导致的覆写失败。
-
Java编译时默认编码非UTF-8,Windows下为GBK,需显式加-encodingUTF-8参数;IDE需统一设置文件编码为UTF-8并重启;运行时应设-Dfile.encoding=UTF-8且终端需支持UTF-8,三者必须一致。
-
Hibernate6.x中使用JPA标准DDL生成配置时,仅设置脚本导出属性无法自动创建数据库表,必须显式指定jakarta.persistence.schema-generation.database.action才能同步更新数据库。
-
Java的Matcher.replaceAll()不支持Perl风格的\U(全大写)或\L(全小写)转义序列,无法通过纯替换字符串实现大小写转换;必须结合String.toUpperCase()或自定义Function<MatchResult,String>进行逻辑处理。
-
JAVA_HOME应指向JDK根目录(如C:\ProgramFiles\Java\jdk-17.0.2),而非jre或bin子目录;其下须含bin、lib等标准子目录,PATH仅需添加%JAVA_HOME%\bin或$JAVA_HOME/bin,并通过echo、where/which和javac-version验证配置。
-
Files.copy()逐个追加写入最稳妥:需显式指定编码、首次写不用APPEND、每文件后写换行符、用try-with-resources关流;混合编码须用BufferedReader逐行转码写入,避免乱码与OOM。
-
接口幂等性指多次调用结果一致,常用实现方式包括:1.唯一标识+Redis缓存,利用SETNX防止重复提交;2.数据库唯一约束,通过唯一索引避免重复插入;3.状态机控制,条件更新确保状态流转幂等;4.Token机制,防重令牌一次性使用。实际中可组合使用,如Redis与数据库约束结合,保障核心操作数据一致性。
-
Java对象序列化依赖java.io.Serializable标记接口,JVM通过ObjectOutputStream.writeObject()检查该接口并默认序列化非transient非static字段;需显式声明serialVersionUID保障版本兼容,transient和static字段因安全或语义原因不参与默认序列化;现代项目更推荐JSON、Protobuf等跨语言方案。
-
ForkJoinTask是ForkJoinPool框架核心,用于分治并行处理计算密集型任务。它有RecursiveTask(有返回值)和RecursiveAction(无返回值)两个子类,通过fork拆分任务、compute执行、join合并结果,结合工作窃取算法提升并发效率,适用于数组求和、排序等场景,需合理设置阈值避免过度拆分,推荐用于CPU密集型任务以发挥多核性能优势。
-
面向对象编程通过封装、继承和多态减少代码冗余。1.继承使子类复用父类代码,共性逻辑集中管理;2.封装将数据与方法绑定,统一访问接口,避免逻辑分散;3.多态允许不同对象响应同一消息,消除条件判断,提升扩展性。抽象共性、分离差异,降低维护成本,增强可读性与复用性。