-
静态成员属于类本身而非实例,JVM在类初始化阶段为其分配唯一内存,所有实例共享;调用不依赖对象,由声明类型决定隐藏行为,与对象无关。
-
Java缓存设计核心是“用得上、管得住、不拖累”,采用本地(Caffeine)+分布式(Redis)两级结构,规范Key命名、JSON序列化、CacheWrapper封装及Cache-Aside更新策略。
-
加号适合简单、固定、编译期可确定的拼接;StringBuilder适合循环、动态、大量拼接。加号对字面量编译优化,但含变量时每次生成新String和StringBuilder;StringBuilder可变、高效、需手动控制容量。
-
Java关闭钩子用于JVM关闭前执行清理操作,如释放资源、关闭连接、记录日志等;需通过Runtime.addShutdownHook()注册未启动线程,避免阻塞与依赖执行顺序,且在kill-9、OutOfMemoryError或Runtime.halt()时失效。
-
Java日志需避开java.util.logging的FileHandler缺陷,优先选Log4j2RollingFileAppender(配append="false"与immediateFlush="true")或调优SLF4J+Logback异步队列,禁用裸Files.write。
-
Java中使用Lambda表达式的核心目的是简化函数式编程写法,提升代码简洁性与可读性。1.Lambda表达式的基本语法为(参数列表)->{方法体},可省略大括号和return;2.必须结合函数式接口使用,如Runnable、Comparator、Consumer等;3.在StreamAPI中发挥强大作用,支持filter、map、collect等操作;4.可自定义函数式接口配合Lambda实现策略模式等逻辑封装。掌握Lambda表达式有助于适应现代Java开发趋势,但需注意保持代码可读性和维护性。
-
ArrayList和LinkedList允许null,但遍历时调用item.toString()等方法会抛NPE;HashMap/HashSet有限支持null,ConcurrentHashMap禁止null;TreeSet/TreeMap默认不支持null,需自定义Comparator;Optional不应作为集合元素。
-
直接newThread()在高并发下易导致OOM和性能崩溃,必须使用显式配置的ThreadPoolExecutor;应避免Executors工具类的无界队列和失控线程数陷阱,选用有界队列、合理拒绝策略与可监控参数。
-
首先调用shutdown()停止接收新任务并等待已提交任务完成,再通过awaitTermination()设置超时等待;若超时或发生中断,则调用shutdownNow()强制关闭,避免资源泄漏。
-
方法重载允许类中多个同名方法共存,只要参数列表不同即可。例如Calculator类中add方法可接受不同数量、类型或顺序的参数,Java根据传入参数自动匹配对应方法,提升调用灵活性与代码可读性。
-
本教程详细指导如何在Java中不依赖数组和Map实现罗马数字与整数的相互转换。我们将重点解决原始代码中罗马数字转整数时出现的无限循环问题,通过将内部while循环改为if判断,并确保对象状态在设置时保持一致,从而构建一个功能完善且易于理解的RomanNumeral类。
-
Paths.get()是Java中创建Path对象的核心方法,属于java.nio.file包,用于安全、跨平台地处理文件路径。1.可通过字符串路径、多段路径或URI构建Path对象,系统自动适配分隔符;2.支持resolve()拼接路径、relativize()计算相对路径;3.提供normalize()清理冗余的“.”和“..”,toAbsolutePath()转绝对路径;4.不检查路径是否存在,仅解析语法,错误时抛InvalidPathException;5.推荐替代字符串拼接,常用于读取配置、构建
-
答案:Java中实现线程安全计数器主要有三种方式:1.使用synchronized修饰方法或代码块,保证同一时刻只有一个线程执行;2.使用AtomicInteger类,基于CAS机制实现无锁高效并发;3.使用ReentrantLock提供更灵活的锁控制。推荐根据场景选择:简单场景用synchronized,高并发用AtomicInteger,复杂控制用ReentrantLock。
-
Java中判断数组是否为空需先检查arr==null再检查arr.length==0,或用Objects.isNull(arr)||arr.length==0;基本类型和引用类型数组判断逻辑相同,禁用Arrays.asList()。
-
ConcurrentHashMap通过分段锁和CAS操作实现线程安全与高性能,允许多线程并发访问不同段,支持put、get、remove等线程安全操作及compute、merge等原子性操作,迭代不抛出ConcurrentModificationException但可能非实时,其内存模型依赖volatile、happens-before原则和内存屏障保证可见性与有序性,相比Hashtable具有更高并发性能,使用时应避免嵌套锁、采用固定加锁顺序以防止死锁。