-
LinkedHashSet严格保持插入顺序,HashSet顺序不可预测,这是由底层结构决定的:前者维护双向链表,后者仅依赖哈希表;序列化后顺序仅在反序列化为LinkedHashSet时保留。
-
静态代码块在类加载时执行一次,用于初始化静态资源;实例代码块每次创建对象时执行、优先于构造器,用于抽取共用初始化逻辑;二者执行顺序严格遵循“父类静态→子类静态→父类实例→父类构造→子类实例→子类构造”。
-
Math.abs()、Math.max()/min()对负零、NaN、无穷大有特殊行为;Math.round()非银行家舍入,仅加0.5后取整;Math.pow()/sqrt()处理负数直接返回NaN;Math.random()线程不安全且精度有限,推荐ThreadLocalRandom。
-
Java中的不可变集合指List.of()、Set.of()、Map.of()等返回的真正不可修改实例,创建后大小、元素、顺序均不可变,任何修改操作抛UnsupportedOperationException,且不共享可变状态;而Collections.unmodifiableXXX()仅为只读代理,原始集合仍可变。
-
答案是Java结合SpringBoot可快速构建问答社区,通过设计questions、answers、users三张表实现数据存储,使用JPA进行持久化,前端用HTML+JS调用后端API完成用户提问、回答、查看与互动功能。
-
最直接方式是运行java-version,但结果取决于PATH顺序;用java-XshowSettings:properties-version|grep"java.home"可查实际路径;java和javac版本可能不一致,需分别验证。
-
Java中try-catch-finally用于异常处理与资源管理,1.try块执行可能出错的代码;2.catch捕获并处理异常;3.finally确保关键代码(如资源释放)始终执行;4.推荐使用try-with-resources自动管理资源,避免冗长代码和遗漏关闭;5.finally无论是否发生异常都会执行,即使try中有return,但System.exit会阻止其运行。
-
Java字段初始化顺序严格按JVM规范执行:先静态(父类→子类,自上而下)、再实例(父类字段/块→父构造→子字段/块→子构造),最后构造器;混合调用易致空指针或默认值问题。
-
java-version仅显示版本,whichjava返回java路径,其上两级目录常为JDK根目录,但需验证是否存在bin/javac;java.home指向JRE或JDK的运行时根目录,非真实JDK路径;JAVA_HOME是用户设定的预期JDK路径,需检查bin/javac是否存在且可执行。
-
volatile写通过内存屏障触发MESI协议使其他核心缓存行失效,并非直接写主存;volatile读通过读屏障禁止重排序并强制重新加载,确保看到的值是最新提交的。
-
HashSet底层基于HashMap实现,元素作key、PRESENT作value,继承其线程不安全、扩容机制等特性;TreeSet基于TreeMap,依赖Comparable或Comparator排序,null处理需谨慎;二者迭代顺序根本不同。
-
HttpURLConnection默认未设请求方法,需显式调用setRequestMethod("GET")或setRequestMethod("POST"),否则首次connect()或获取流时抛IllegalStateException;GET须setDoOutput(false),参数拼URL;POST必须setDoOutput(true)并设Content-Type;响应体需按Content-Type中charset手动解码,禁用String.getBytes()无参版;超时需pre-connec
-
观察者模式通过被观察者状态变化时自动通知所有依赖的观察者实现一对多更新,常用于事件处理、GUI交互与数据同步;核心为Subject维护Observer列表并触发update方法,Java中可通过自定义接口或过时的Observable类实现,适用于解耦事件源与处理逻辑,需注意性能与内存泄漏问题。
-
使用多个catch块可分别处理不同异常,JVM按顺序匹配首个符合的异常类型,提升代码可读性与维护性。
-
本文讲解如何用Java实现:读取文件A的每一行,然后在文件B的全部内容中查找该行是否包含任意一个B中的名字;若匹配成功,则将该行写入结果文件。核心在于避免Scanner无法重置的问题,通过循环内重建Scanner实现重复读取。