-
ThreadDeath是Thread.stop()主动抛出的Error,非系统崩溃,但会破坏线程状态、跳过finally、导致资源泄漏和锁不一致;stop()已废弃,应改用interrupt()+响应式退出机制。
-
Arrays.parallelSort从Java8引入,适用于大数组并行排序,利用多核提升性能,对小数组退化为普通sort以避免开销,支持基本类型和对象数组自定义比较,需结合数据规模与硬件环境合理使用。
-
死锁典型场景是线程间嵌套加锁顺序不一致;应按对象哈希值升序加锁、避免锁内调用外部方法、缩小同步范围;推荐用ReentrantLock.tryLock()超时机制规避;jstack和ThreadMXBean可检测死锁;LockSupport.park/unpark误用亦致逻辑死锁;根本解法是消除共享可变状态。
-
控制台项目初期不应分模块,建议前两周所有类平铺在一个包中;待核心流程跑通后再按职责切分,优先合并状态强耦合类;main()应避免裸while循环,改用命令解析+业务调用分离;状态统一由HallContext单例管理并序列化持久化;Windows下需统一编译、运行及IDE终端编码为UTF-8。
-
本文详解在无网络环境下,通过--offline模式构建SpringBoot项目时,如何正确配置本地插件(如spring-boot-gradle-plugin),包括插件命名规范、buildscript依赖声明、必需的传递依赖(如spring-boot-loader-tools)及离线依赖管理最佳实践。
-
Java程序启动慢主要源于JVM冷启动、容器内存配置不当、SpringBoot自动扫描与配置、熵源不足及JIT预热延迟;需优化JVM参数、缩小扫描范围、启用CDS、替换随机数源并评估GraalVM原生镜像。
-
重载方法必须在同一个类中定义,判断依据仅为参数列表(数量、类型、顺序),与返回值无关;调用在编译期按变量声明类型绑定,不跨类追溯,泛型擦除可能引发重载冲突。
-
本文详解Windows环境下Hadoop(3.2.1)因JAVA_HOME配置异常导致hdfsnamenode-format失败的问题,涵盖环境变量验证、路径规范、脚本覆盖风险识别及完整修复步骤。
-
accessOrder必须显式设为true才启用访问顺序,使get()或put()已存在key时将对应Entry移至链表尾部;默认false按插入顺序维护,LRU失效。
-
String.lines()返回空流是因为原始字符串不含换行符(\n、\r\n、\r);它语义化分割且不保留终结符,而split()需手动匹配换行变体并可能产生空串。
-
继承可提升代码复用性、支持多态、建立清晰层次关系,但应避免过度使用、误用has-a关系、破坏封装及忽略父类逻辑,合理结合组合与接口。
-
Deque接口支持双端操作,提供addFirst/offerFirst、addLast/offerLast、removeFirst/pollFirst、removeLast/pollLast等方法,推荐使用offer和poll系列避免异常;可高效模拟栈行为,通过push、pop、peek实现后进先出,适用于表达式解析、括号匹配、DFS等场景;在滑动窗口问题中维护单调队列,利用下标存储与队尾比较保持单调性,将时间复杂度从O(nk)优化至O(n);遍历时可使用iterator()或descendingIter
-
UUID.randomUUID()是最常用也最容易出错的起点Java里生成唯一ID,UUID.randomUUID()是第一反应,但它生成的是128位随机UUID(version4),不是递增、不带时间信息、字符串长度固定36字符(含4个短横线)。很多人直接用它当数据库主键,结果发现索引性能差、存储冗余、排查日志时还得手动去掉短横线。别在高频插入场景(比如订单流水表)直接用UUID.randomUUID().toString()作主键——B+树索引会因随机写导致页分裂严
-
Jenkins中Java11不生效需依次确认:JDK在GlobalToolConfiguration中显式配置且JAVA_HOME为绝对路径;流水线中用tools指定而非withEnv或export;Maven/Gradle插件及源码兼容Java11(如添加javax.annotation-api、升级Lombok);Agent进程环境变量(systemd/NSSM中显式设置JAVA_HOME)。
-
使用ConcurrentHashMap、Future+Callable、ReadWriteLock或Caffeine等方案可实现Java线程安全缓存。1.ConcurrentHashMap适用于高并发读写场景,通过分段锁或CAS保证线程安全;2.Future方案结合原子操作避免多线程重复计算,提升性能;3.ReadWriteLock提供读写锁分离,适用于强一致性要求的批量更新;4.推荐使用Caffeine或GuavaCache等成熟库,内置线程安全与自动加载机制,简化开发。核心是避免竞态条件并控制读写互斥