-
动态修改核心线程数需明确setCorePoolSize()仅重定义后续创建规则:调大不立即建线,调小不中断运行线程;须配合prestartAllCoreThreads()预热、allowCoreThreadTimeOut(true)缩容回收,并接入配置中心、设置校验与监控告警。
-
从订单列表接口慢查询复盘 MyBatis nested select 的 N+1 风险,讲清 JOIN nested results、两段批量查询、分页 count 和上线检查。
-
Optional是明确表达“可能为空”意图的容器,适用于查找、解析等可能无结果的函数返回值,而非替代null或用于字段类型;应避免常见误用如Optional.of(null)、实体类中使用Optional、混淆map/flatMap等。
-
用带种子的Random分层抽样可复现组卷;多信号叠加检测+服务端心跳校验防作弊;时间同步需用服务端时间戳对齐。
-
Java的PreferencesAPI并不直接生成可读路径或用户可见的XML文件;其底层存储机制因操作系统而异(Windows注册表、macOSplist、Linux二进制文件),且路径经哈希处理,故出现“乱码目录”属正常行为,非错误——开发者应避免依赖文件系统路径,而应通过API读写键值。
-
IntelliJIDEA自动保存失效需检查三处:勾选“Savefilesonframedeactivation”和“Savefilesautomaticallyifidle”,并确认“Savefilesonbuild”已启用;插件冲突(如Metals、Lombok)可能干扰保存;外部进程(如Maven编译、DevTools)重写文件导致“文件已更改”提示。
-
Properties类用于读取键值对配置文件,继承Hashtable且线程安全。1.可通过FileInputStream加载文件;2.推荐使用ClassLoader读取resources目录下的配置文件;3.常用方法包括load、getProperty、setProperty和store;4.注意编码问题、流关闭、敏感信息保护及封装为单例提升性能。
-
用sdkman管理JDK最省心:Linux/macOS执行curl安装后,用sdklist/install/use/default切换版本;Windows推荐choco安装+IDE或.tool-version文件指定版本,避免JAVA_HOME错误导致编译失败。
-
printStackTrace是Throwable及其子类的实例方法,必须通过异常对象调用,如e.printStackTrace();默认输出到System.err,可重定向至文件或日志框架;区别于getMessage/toString,它包含完整堆栈轨迹,但生产环境应避免裸用,需结合上下文与日志级别控制。
-
正确配置依赖可提升Java开发效率。应优先使用Maven/Gradle管理依赖,在pom.xml中添加依赖项后自动导入,或手动添加JAR包为库(不推荐),并通过统一工具、定期更新、分析无用依赖和启用自动导入优化管理。
-
Hashtable能直接多线程使用因其所有public方法均加synchronized锁,HashMap无同步机制,多线程并发put可能导致扩容死循环或数据丢失,且其迭代器fail-fast,结构变更即抛ConcurrentModificationException。
-
Class.getResourceAsStream路径以/开头才从classpath根查找,否则按当前类包路径相对查找;文件需在src/main/resources下且构建后存在于jar顶层;返回null主因是路径错误、资源未进classpath或IDE缓存未刷新。
-
PATH变量不直接参与Java编译运行,但决定java、javac等命令能否全局执行;它通过指定JDK的bin目录使系统能定位可执行文件,修改后需刷新终端或重启IDE,且须确保添加的是bin路径而非JDK根目录。
-
getMessage()返回异常构造时传入的消息字符串(可能为null),toString()返回“类名:消息”,含类型信息但消息为null时显示“:null”。
-
ZGC采用彩色指针而非“深色指针”,其核心目标是实现亚毫秒级暂停,回收对象堆内存而非“变量”,不追求“秒级回收”。