-
成员代码块是类中用{}包裹、不在任何方法内的无名代码段,每次new对象时自动执行且位于所有构造函数体之前;编译器将其插入每个构造函数super()/this()调用之后,用于统一处理与参数无关的初始化逻辑。
-
公平模式(fair=true)启用FIFO调度,避免线程饥饿但吞吐量降低15%–30%;非公平模式允许插队、提升吞吐,但可能引发延迟波动与个别线程长期等待。
-
直接用代码块初始化不同版本的API实例是最轻量、最可控的变量路由解法,通过独立实例隔离版本逻辑,自动加前缀、差异化中间件、分版本监控,并用结构体嵌套保障响应兼容性。
-
默认Propagation.REQUIRED导致嵌套方法共享事务,内层异常会标记整个事务rollbackOnly,外层catch无法阻止回滚;REQUIRES_NEW可隔离事务,NESTED仅依赖数据库savepoint且不可靠。
-
在Java中使用HttpURLConnection设置User-Agent需在connect()前调用setRequestProperty("User-Agent",uaString),推荐使用主流浏览器真实UA字符串,但仅设UA不足以完全模拟浏览器,还需配合其他头部及请求策略。
-
Reference.reachabilityFence并非修复NPE的万能药,而是防止JVM过早判定对象不可达的编译器屏障;它仅在对象本应可达但因激进优化(如逃逸分析)被误回收时生效,且必须紧邻最后一次使用、在同一栈帧内调用,配合Cleaner或PhantomReference使用才有效。
-
POSITIVE_INFINITY是边界标记值,用于表示无上限或跳过约束,不可直接赋给速度参与物理计算;需配合isfinite()检查,在速度钳制、CCD开关等场景中作为配置语义值使用。
-
答案是:用jstack查RUNNABLE线程中是否反复出现getEntry或transfer栈帧,结合MAT分析heap.hprof确认next互指环。死循环表现为CPU100%、无异常、多线程卡在e=e.next且地址交替,根源是JDK7扩容时头插法与竞态导致A↔B环。
-
老年代担保失败是JVM在MinorGC前预判风险后主动触发FullGC的结果,关键在于检查时机(GC前)、判断依据(连续空闲空间≥晋升量或历史均值)和退路选择(直接FullGC而非补救)。
-
包可见性是Java中一种恰到好处的封装手段,使成员仅对同包类可见,兼顾内聚协作与边界控制,需配合功能导向包结构和同包测试实践。
-
InetAddress.getLocalHost()返回127.0.0.1是因主机名被解析为localhost,应遍历网卡获取真实局域网IP;getByName()失败多因DNS缓存、IPv6优先或防火墙;isReachable()在Windows下不可靠;getCanonicalHostName()强制正反向DNS解析确保FQDN。
-
Java字符串转义最易出错的是反斜杠(\\)和双引号(\"),因编译期解析导致路径、正则、JSON等场景需双重转义;Unicode转义\uXXXX须4位且UTF-8编码;应优先使用专用序列化库而非手动拼接。
-
抽象类构造方法是子类对象创建时强制执行父类初始化逻辑的唯一时机,通过super()调用完成final字段校验赋值、共享资源注入,并禁止调用抽象方法,且子类必须显式调用super()。
-
JAVA_HOME指向哪个目录才真正有效必须指向JDK的根目录,不是JRE目录,也不是bin子目录。常见错误是把JAVA_HOME设成C:\ProgramFiles\Java\jdk-17.0.1\bin——这会导致几乎所有依赖它的工具(如Maven、Gradle、IDE)报“找不到Java”或“java.lang.NoClassDefFoundError”。JDK根目录下得有lib、jre(或conf)、bin三个关键子目录。✅正确示例:C:\Program
-
多态通过继承、方法重写和父类引用指向子类对象实现,使同一方法调用在不同对象上产生不同行为。Java中多态的实现依赖JVM的动态分派机制,运行时根据实际对象类型通过虚方法表(vtable)确定具体方法版本,确保正确调用子类重写的方法。示例中Animal父类引用指向Dog和Cat子类实例,调用makeSound()时分别执行各自重写逻辑,输出"Woof!"和"Meow!"。该机制仅适用于可重写的实例方法,不适用于静态方法、私有方法或成员变量。多态广泛应用于参数类型统一、集合存储多态对象及框架设计中抽象行为的实