java教程技术文章
-
notifyAll()仅将等待线程移入锁竞争队列,不直接执行;线程需重新竞争锁,且wait必须用while循环检查条件,配合同一volatile或同步保护的条件变量,并在synchronized块中对同一对象调用。484 收藏 -
Runtime.gc()不会强制触发垃圾回收,仅是向JVM发出建议,实际执行与否由JVM决定;生产环境中调用基本无效,还可能干扰GC策略。484 收藏 -
localStorage仅适合存储非敏感、可公开的轻量数据,如主题偏好、表单草稿、界面状态、“记住我”UI状态、排序筛选偏好;必须用JSON.stringify()写入、JSON.parse()读取并处理null和异常;禁存密码、token等敏感信息。484 收藏 -
直接用==比较double常出错,因其二进制无法精确表示多数十进制小数(如0.1),导致微小舍入误差;Double.compare仅比较位模式是否完全相同,不支持容差,不能替代epsilon比较。484 收藏 -
应避免用异常代替控制流、滥用检查型异常、在finally中抛异常及自定义无上下文异常;正确做法包括用分支判断替代异常控制、封装检查型异常、使用try-with-resources、提供错误码/参数/cause的自定义异常。484 收藏 -
数组长度固定,查找可通过遍历实现,如for循环定位目标元素索引。484 收藏 -
ThreadLocal的值存在当前线程的threadLocals字段(ThreadLocalMap类型)中,而非ThreadLocal实例本身;get/set操作本质是对此Map的key(当前ThreadLocal)查/存value;因Entry的key是弱引用而value是强引用,若不显式remove(),易导致value内存泄漏,尤其在线程池场景下。484 收藏 -
默认GC在生产环境大概率不合适,因其未适配真实负载如堆外内存压力、GC停顿敏感度等;RPC网关或实时计费系统中一次2秒FullGC即可引发下游熔断。484 收藏 -
责任链模式实现多级审批的关键在于流程可配、节点可插拔、跳过有依据、终止有控制;节点通过shouldHandle动态判断介入,链由配置驱动组装,传递过程需防崩溃、状态隔离、空安全,并统一归口审批结果。484 收藏 -
Java编译器允许看似不可达的代码(如恒真条件后的else块)存在,是为了支持调试标志(featureflags)等开发实践,而非因逻辑分析能力不足;该设计符合JLS规范,兼顾可维护性与编译期检查的实用性。483 收藏 -
Arrays.copyOf()和clone()都只做浅拷贝,即复制数组引用而非对象实例;二者性能相近,但clone()略快且可读性差;深拷贝需手动遍历构造或谨慎使用序列化。483 收藏 -
Java项目集成Swagger推荐使用SpringDocOpenAPI(Swagger3),需引入springdoc-openapi-starter-webmvc-ui依赖,配置扫描包和UI路径,通过@Tag、@Operation等注解管理接口分组与描述,启动后访问/swagger-ui即可查看文档。483 收藏 -
使用Comparator.comparing()可实现List按属性排序,如按age升序:people.sort(Comparator.comparing(Person::getAge));支持多属性排序thenComparing()、降序reversed(),或通过Stream生成新列表避免修改原数据。483 收藏 -
DecimalFormat.format()不显示两位小数是因为模式中使用了“#”而非“0”、setMinimumFractionDigits()被错误设置,或double精度问题未预先舍入;正确做法是用"0.00"模式、避免干扰设置,并用BigDecimal或Math.round预处理数值。483 收藏 -
SynchronousQueue是零容量同步通道,不存储元素,put与take必须配对阻塞完成“手递手”交付,无缓冲、无复制、无中间状态,仅在生产者与消费者线程间直接传递引用。483 收藏