-
Java仅支持8种基本类型及其对应包装类之间的自动装箱/拆箱,如int↔Integer、boolean↔Boolean等;其他类型不支持,编译失败。
-
验证阶段首先校验Class文件魔数是否为0xCAFEBABE、主版本号是否在JVM支持范围内,未通过则抛出ClassFormatError或UnsupportedClassVersionError并终止加载。
-
Java编译器默认只为源文件中声明的public顶级类生成独立.class文件,且该类名必须与文件名(含大小写)严格一致;其余非public顶级类会被编译进同一.class文件中,不对外暴露。
-
导出CSV必须用try-with-resources关闭BufferedWriter,字段含逗号或中文需加英文双引号;导入不可用split(","),应使用OpenCSV或手动解析引号;统一指定UTF-8编码并处理BOM头,Contact应为POJO。
-
任务类需强制非空校验、状态封装为枚举、ID用Long或UUID、setter链式返回且禁设null;单线程用ArrayList配合synchronizedList,禁用Vector和盲目用CopyOnWriteArrayList。
-
Collections.addAll()不能初始化空集合,只能向已创建的可变集合(如ArrayList)批量添加元素;正确做法是先创建集合实例,再调用该方法。
-
ZGC采用彩色指针而非“深色指针”,其核心目标是实现亚毫秒级暂停,回收对象堆内存而非“变量”,不追求“秒级回收”。
-
Java中不能靠抛异常实现优雅退出,因为异常机制非流程控制工具,会掩盖错误、破坏调用栈、干扰监控;应使用System.exit(int)明确退出意图,或采用分层返回与外部信号协调。
-
ArrayList的elementData声明为transient是为了跳过JVM默认序列化,仅序列化size及有效元素,避免冗余null占位导致体积膨胀、语义失真及兼容性风险,并为自定义writeObject/readObject提供前提。
-
用StreamAPI对轨迹点距离聚合的核心是reduce滑动配对:以double[]{0.0}为累加器,每次计算a.distanceTo(b)后返回b推进链式处理;并行需慎用,仅多轨迹场景适用;预处理建议filter去噪、map转单位;可封装为Collector复用。
-
Java中文件读写主要使用java.io包,根据需求选择字符流或字节流;处理文本文件可用FileReader/FileWriter逐字符操作,或BufferedReader/BufferedWriter按行高效读写;二进制文件则用FileInputStream/FileOutputStream配合缓冲数组复制;JavaNIO.2的Files类提供简洁API适合小文件操作;所有方式均需处理IO异常并确保资源关闭。
-
要实现PrintService对变量文档的异步打印控制,需解耦调度与执行,用ExecutorService或CoroutineScope管理后台任务,在onPrintJobQueued()中提交异步任务并保存PrintJob引用;每个PrintJob封装为可取消的PrintUnit,含元数据、状态、CancellationToken及回调;动态生成文档(如PdfDocument绘制)须在子线程完成并写入PrintDocument.getOutputStream();通过SparseArray<Pri
-
序列化是将内存中对象的状态转换为字节流以持久化或传输,反序列化则还原对象;必须实现Serializable接口标记允许序列化,子类继承时建议显式实现,非transient非static字段须可序列化,serialVersionUID需手动维护确保兼容性。
-
Mixin必须与目标类结构严格匹配,方法、字段、构造器签名需完全一致;否则Jackson会退回到默认反射逻辑并报错。
-
模块化系统不能直接限制Unsafe操作,但能提高滥用门槛和可检测性:通过封装隐藏访问路径、显式声明opens权限、隔离专用模块、启用非法访问禁止策略,并用VarHandle等标准API替代。