-
自动装箱发生在哪些地方自动装箱不是“运行时偷偷转换”,而是编译器在编译期就插入了Integer.valueOf()、Boolean.valueOf()这类调用。只要类型匹配且上下文需要包装类,就会触发——比如赋值给包装类型变量、作为泛型参数传入、放进集合(ArrayList)、或者调用接收包装类的方法。常见错误现象:NullPointerException在看似安全的算术操作中爆发,比如Integera=null;intb=a+1;——这里解包时才会抛异常,不是装箱时。
-
NumberFormatException在字符串格式非法时抛出,如空串、纯字母、多余空格、Unicode零宽字符或超范围数值;应通过trim()校验、null检查及try-catch或Optional封装安全转换。
-
ClassCastException根本原因是同一类被不同类加载器加载,导致JVM视为不同类型;需通过堆栈分析、运行时打印加载器、检查依赖冲突、JVM参数及Arthas工具定位并统一类加载边界。
-
Java核心概念需通过实践深挖:ArrayList初始容量不等于数组长度,volatile对long/double在现代JVM中主要起内存屏障作用,ClassLoader.loadClass()返回null主因是类名错误或类路径缺失,String.intern()自JDK7起存于堆内字符串常量池。
-
Java程序运行核心是写对源文件名与类名、配好JDK环境变量;需确保javac/java命令可用,文件名与public类名严格一致,编译运行在正确路径下,注意大小写敏感和包声明规则。
-
Unsafe.allocateMemory绕过GC需配对freeMemory,否则内存泄漏或崩溃;putX/getX无边界检查易越界;禁混用DirectByteBuffer地址;新项目应优先使用MemorySegment+VarHandles。
-
Java中用static修饰的方法叫静态方法,它属于类本身,不依赖对象实例就能调用,只能直接访问静态成员,不能使用this或super,也不能调用非静态成员。
-
OutputStreamWriter的核心作用是将字符按指定编码转换为字节并写入底层字节流,作为字符流与字节流间的编码桥梁;必须包装现有OutputStream,需显式指定编码(如UTF-8),写入后应flush或close,可配置错误处理策略。
-
本文介绍如何在Java中高效、安全地解析结构不统一的JSON数据,避免大量冗余的has()判断,通过封装泛型安全访问方法提升代码可读性与健壮性。
-
需穿透多层异常封装定位根本原因:逐层调用getCause()或getRootCause(),识别InvocationTargetException、UndeclaredThrowableException等反射包装异常,结合堆栈中的Method.invoke等反射入口及字节码验证,辅以日志配置%ex{full}和框架配置优化。
-
exceptionally仅捕获上游异常,不处理null等业务失败值;handle则统一响应成功与异常,需手动判空,且其中抛异常会传播,而exceptionally中抛异常会被吞掉。
-
使用Java实现订单打印需定义订单数据模型并利用String.format()控制输出格式,通过封装printOrder方法实现清晰对齐的文本排版,支持控制台或文件输出。
-
LockSupport是Java中用于线程阻塞与唤醒的核心工具类,位于java.util.concurrent.locks包下,其核心方法为park()和unpark(Threadthread)。park()使当前线程阻塞,直到其他线程调用该线程的unpark方法或线程被中断;unpark()则向指定线程发放许可,允许其继续执行,且可先于park()调用生效。相比wait/notify机制,LockSupport更灵活安全,不依赖synchronized关键字,也不会因顺序问题导致死锁。它基于单一许可机制
-
适配器模式是“套一层壳”而非修改原接口,因AudioPlayer等已上线类无法直接改动;它通过实现目标接口并持有适配者实例来透明转发调用,真正干净的适配器代码应很薄。
-
静态导入适用于频繁调用来源明确、语义清晰的静态成员,如JUnit断言、Math工具方法或自定义工具类;应避免过度使用导致可读性下降。