-
直接删除config目录比点击「RestoreDefaults」更彻底,因其清除编译器配置、Maven/Gradle路径、SDK绑定等关键设置,而按钮仅重置部分UI偏好。
-
BindException是操作系统报出的端口占用异常,表明JVM尝试绑定的端口(如8080)已被其他进程占用;常见于SpringBoot启动卡在Web服务器初始化阶段,需用lsof、netstat或netstat-ano定位并终止冲突进程,或通过配置server.port、VM参数、Docker端口映射等避免重复绑定。
-
合理使用Optional可避免空指针异常,提升代码安全性和可读性。1.用Optional.ofNullable封装可能为null的对象,如用户为空时姓名设为“未知用户”;2.通过orElse提供默认值,高开销场景优先使用延迟加载的orElseGet;3.利用map链式转换嵌套属性,自动规避中间null值;4.避免直接调用get(),应结合ifPresent等方法进行安全操作。核心是将判空转为流程控制,但不宜滥用作字段或集合元素。
-
本文详解Stringa="hello";Stringb=a+"bye";执行过程中JVM实际创建的String对象数量,明确区分字符串常量池与堆内存中的对象生成逻辑,并澄清关于"bye"是否入池、StringBuilder.append()是否触发新字符串创建等常见误区。
-
Ubuntu用户应优先使用apt安装OpenJDK(如openjdk-21-jdk),避免手动解压tar.gz;装完需配置JAVA_HOME并重载shell配置,IDE和CI脚本需单独处理环境变量或直接调用/usr/bin/java。
-
直接拼接JSON字符串易生成非法JSON,导致前端SyntaxError或后端JsonParseException;根本原因是未按JSON规范转义双引号、反斜杠、换行符等;应使用ObjectMapper.writeValueAsString()自动处理转义与格式化。
-
jstack-l<pid>可快速抓取线程快照并识别死锁,输出中出现“Found1deadlock.”即表明检测到循环等待导致的死锁,但仅覆盖synchronized和JUC显式锁,不包括StampedLock、外部资源锁等。
-
Optional不应用于集合元素,应在数据入集前过滤null;推荐用stream().filter(Objects::nonNull)或removeIf(Objects::isNull),注意源头过滤、避免NPE、区分业务空值。
-
浅拷贝仅复制对象自身字段,引用类型共享;深拷贝需手动逐层复制或序列化,但序列化有性能、安全及兼容性限制,无通用银弹。
-
Eclipse高效开发需掌握核心快捷键与工作空间设置:Ctrl+Space补全、Ctrl+Shift+R/T查资源/类、Ctrl+O定位成员、F3跳转声明、Ctrl+1快速修复;工作空间须独立使用、定期清理、设UTF-8编码与LF换行符。
-
ClassCircularityError是JVM在类加载链接阶段检测到类定义存在直接或间接自引用时主动抛出的LinkageError,不抛StackOverflowError因其发生在字节码执行前、无递归调用栈。
-
Redis预减库存必须用DECRBY而非GET+SET,因后者存在竞态条件导致超卖;DECRBY原子性防超卖,需配合EXISTS校验key存在、检查返回值是否为负、Lua脚本封装操作,并在DB层用WHEREstock>0二次校验。
-
substring(intbeginIndex)合法索引范围是0到字符串长度(含),如"abc".substring(3)返回"",但substring(4)越界;空串时s.length()-1为-1会抛异常,需先判空;substring(begin,end)为左闭右开区间,长度等于end-begin。
-
G1适合堆内存4GB-16GB、停顿几百毫秒可接受的场景;ZGC适用于超大堆、延迟敏感且CPU充足的环境,需JDK17+生产推荐,实测验证必不可少。
-
<p>ArrayList扩容机制在添加元素时触发,当元素数量超过底层数组容量便调用grow()方法;首先计算最小所需容量为size+1,旧容量为原数组长度,新容量默认为旧容量的1.5倍(oldCapacity+(oldCapacity>>1)),若仍小于最小容量则以最小容量为准,若超出Integer.MAX_VALUE-8则调用hugeCapacity处理;随后创建新数组并复制原数据。例如初始容量10,第11个元素加入时扩容至15。默认初始容量为10(JDK1.8首次add时初始化