-
Logback异步日志需显式配置queueSize(256–1024)和discardingThreshold=0,禁用includeCallerData,搭配RollingFileAppender并验证AsyncAppender-Worker线程及QUEUE_FULL警告。
-
interrupt()不生效的主因是线程未响应中断:纯计算循环未检查isInterrupted()、吞掉InterruptedException未重设标志、阻塞IO不响应、守护线程无法用于超时控制;可靠方案是Future+ExecutorService配合任务内中断检查。
-
对象锁和类锁互不阻塞,因锁对象不同(thisvs类.class);对象锁仅限同一实例,类锁全局唯一;应缩小锁粒度、选稳定锁对象、按共享变量类型匹配锁机制。
-
Java类加载器无法卸载类,热更新实为用新ClassLoader加载同名类并让旧类被GC回收;需确保旧类实例彻底不可达、使用独立URLClassLoader、避免静态引用;常见陷阱包括static字段未清理、线程未终止及JNI资源泄漏。
-
二进制分发版JDK是官方预编译的.tar.gz或.zip包,解压即用,需手动配置JAVA_HOME和PATH指向根目录,不修改系统路径或注册表,适用于多版本共存、容器部署及生产环境精准控制。
-
最常用Java格式化输出方式是System.out.printf()和String.format()。前者直接输出到控制台,后者生成字符串;支持%d、%f、%s等占位符,可控制宽度、对齐(如%-10s)和精度(如%.2f),推荐用%n换行,结合DateTimeFormatter可格式化时间。
-
本文介绍两种安全、高效的Java方式,从外层HashMap中按内层"date"字段条件(如过期时间)批量删除对应条目:一种是函数式流式重建新Map;另一种是使用迭代器原地删除,避免并发修改异常。
-
BufferedWriter适合频繁写入小数据的场景,内部缓冲减少I/O调用;需显式flush或close确保落盘;newLine()适配平台换行,跨平台解析建议统一用"\n"。
-
使用PDFBox3.0保存PDF时,若将正在读取的源文件直接作为save()的目标路径,会导致文件结构损坏、解析异常及内容丢失——这是3.0版本明确禁止的行为,与2.x的宽松策略有本质区别。
-
ArrayDeque是更优选择,因其底层为循环数组、O(1)出入队、无节点开销、GC压力小;LinkedList仅在需removeFirstOccurrence等特有方法时适用。
-
LongAdder在高并发频繁更新时比AtomicLong快,因其采用分段计数减少CAS自旋争抢;适用于监控计数等弱一致性场景,不适用于强一致序列号生成。
-
分布式限流算法的选择需根据业务需求和系统特性进行权衡。1.令牌桶允许突发流量,适合短暂高并发场景,通过Redis+Lua实现令牌生成与消耗的原子操作;2.漏桶以恒定速率处理请求,输出平滑但不适用于突发流量,可通过Redis队列模拟实现;3.计数器分为固定窗口和滑动窗口,后者更精确但实现复杂,适合对限流精度要求高的场景;选择时需考虑一致性、性能开销、容错性、突发流量容忍度及实现复杂度;使用Redis时需防范单点故障、网络延迟、Lua脚本复杂度过高等问题,并通过压测评估吞吐量、延迟和资源消耗,结合监控确保限流
-
Future.get(long,TimeUnit)超时仅终止等待而非任务本身,因任务线程阻塞时不响应中断;cancel(true)是否生效取决于任务是否检查并处理中断信号。
-
Java有8种基本数据类型,均为非对象的原始值类型;整型按范围选byte/short/int/long,int最常用;float/double存在精度陷阱,金融场景用BigDecimal;char和boolean有特殊默认值与比较逻辑;Java无内置无符号类型,但提供工具方法支持无符号运算。
-
在SpringJPA的多对多关系中,直接提交仅含名称(无ID)的关联实体会导致重复插入;JPA无法自动识别“同名即同一实体”,必须显式查库并绑定已存在对象,而非依赖CascadeType.ALL全量级联。