-
Java数组声明有int[]a和inta[]两种语法,语义相同但前者更推荐;初始化分静态(如String[]s={"a"})和动态(如newdouble[5]);访问越界抛ArrayIndexOutOfBoundsException,空引用访问抛NullPointerException。
-
JUC并发工具类解决了传统并发编程中synchronized和wait()/notify()的粒度粗、灵活性差、易出错等问题,1.提供ReentrantLock实现更细粒度的锁控制,支持tryLock、lockInterruptibly等特性;2.通过ExecutorService线程池高效管理线程资源,降低创建销毁开销;3.使用Atomic系列原子类实现无锁线程安全操作;4.利用CountDownLatch、CyclicBarrier、Semaphore等同步器协调复杂线程协作;5.引入Conditio
-
工厂模式与抽象工厂模式解决不同层级创建需求:前者解耦单一产品族,后者支持多产品族组合创建;SimpleFactory适合轻量级同类型实例创建,FactoryMethod适用于框架扩展,AbstractFactory强调产品族一致性协同工作。
-
类加载阶段包括加载、链接(验证、准备、解析)、初始化三步;准备阶段赋静态变量默认值,初始化阶段执行static块和显式赋值,且同一类加载器下仅初始化一次。
-
根本原因是CharsetDecoder仅做字节到字符的严格转换,不处理BOM、编码声明或实际编码与声称编码不符的问题;需先确认真实编码、手动处理BOM、显式设置错误策略,并优先使用高层API。
-
Terminated状态是线程自然终结的标志,仅当run()正常结束或抛出未捕获异常时进入;不可强制设置,stop()等暴力方法已废弃,推荐用interrupt()配合isInterrupted()或volatile标志协作退出。
-
Java将类元数据从永久代移至元空间,旨在解决PermGen内存固定、易OOM、GC耦合度高及职责混乱等问题;元空间基于本地内存按需分配、支持动态扩容与即时回收,提升JVM稳定性、可维护性及对动态语言的支持能力。
-
Files.lines()必须用try-with-resources显式关闭,否则文件句柄泄露易致“Toomanyopenfiles”;正确写法是将Stream声明在try括号内,确保异常或正常退出时自动调用close()释放资源。
-
虚拟线程不改变I/O的阻塞性质,仅通过JVM调度实现阻塞时自动卸载,使同步阻塞I/O(如JDBC、Socket)在高并发下不卡死;无需改IO代码,但需用newVirtualThreadPerTaskExecutor、避坑synchronized长临界区及Object.wait()。
-
Collections.rotate()的偏移量可正可负:正数表示向右循环移动(末尾元素移到前面),负数表示向左循环移动(首元素移到后面),且自动对集合长度取模。
-
ServiceLoader是JDK原生SPI机制,通过META-INF/services/下接口全限定名配置文件加载实现类,懒加载、无参构造、不支持依赖注入,与Spring完全隔离,适用于简单插件场景。
-
HashSet能自动去重,因其底层基于HashMap,元素作为key存储,依赖equals()和hashCode()保障唯一性;自定义类必须正确重写这两个方法,否则去重失效。
-
模块化开发中变量暴露边界的本质是按需开放访问权限:包内用default实现高内聚协作,继承体系用protected+private控制能力边界,对外服务用public配合校验与防御性拷贝,再通过module-info.java二次过滤导出包。
-
真正导致堆栈轨迹极度碎片化的是异步边界跨越叠加异常创建,而非闭包嵌套本身;应通过上下文透传、禁用无意义异常、结构化并发收编来解决。
-
一篇 Java/Spring Boot 集成测试实战:用 Testcontainers 和 JUnit 5 让数据库、迁移脚本、约束和 CI 行为更接近生产,解决 H2 测试全绿但预发翻车的问题。