-
正确配置依赖可提升Java开发效率。应优先使用Maven/Gradle管理依赖,在pom.xml中添加依赖项后自动导入,或手动添加JAR包为库(不推荐),并通过统一工具、定期更新、分析无用依赖和启用自动导入优化管理。
-
AtomicLong在高并发计数场景下比synchronized更稳,因其基于CAS无锁机制,避免阻塞与上下文切换,响应达微秒级;但须正确使用incrementAndGet(),且注意硬件极限与volatile内存语义。
-
Javasubstring需确保起始索引≥0、结束索引≤字符串长度,单参数截取至末尾,双参数左闭右开;处理emoji等需用codePointCount避免代理对截断;Java7u6后无内存泄漏。
-
Java中用Map实现简单缓存的核心是使用ConcurrentHashMap存储键值对,并添加过期控制(如TTL时间戳校验)和容量限制(如LinkedHashMap+LRU),适用于低并发、非关键业务场景。
-
本文详解为何“多线程顺序执行”是反模式,阐明应使用单线程串行调度(如HandlerThread、ExecutorService单线程池)替代混乱的多线程嵌套,并提供安全更新RecyclerView的最佳实践。
-
多数业务应优先用shutdown(),它拒绝新任务但等待已有任务完成;shutdownNow()强制中断运行中线程并返回未执行任务,仅适用于超时不可接受的场景。
-
fail-fast的核心是检测集合结构被意外修改而非并发;ArrayList的modCount在结构性修改时自增,迭代器构造时复制为expectedModCount,next()/hasNext()前比对二者,不等则抛ConcurrentModificationException。
-
静态方法不能直接访问非静态成员变量,因其属于类而非对象实例,且静态方法在类加载时即可调用,而实例变量需对象创建后才存在;静态方法无this引用,无法定位具体实例。
-
ReentrantReadWriteLock通过读写锁分离提升高读低写性能:读锁共享可重入,写锁独占可重入,读写互斥但读读不互斥;支持写锁降级为读锁,禁止读锁升级;适用于缓存等场景。
-
Stream.distinct()不保证顺序,仅在有序流中保留首次出现元素;并行流下顺序失控,需用LinkedHashSet手动去重或Collectors.toMap按字段去重。
-
subList返回原List的实时视图而非副本,其add/remove会直接修改原列表结构并引发索引位移,遍历时修改易抛ConcurrentModificationException或IndexOutOfBoundsException。
-
本文详解如何在Android中实现一个严格对齐“每5分钟整点”(如02:35、02:40、02:45)启动的倒计时器,支持动态计算距下一个5分钟刻度的等待时长,并自动执行5分钟倒计时任务。
-
DateTimeFormatter.parse()抛DateTimeParseException主因是格式模式与输入字符串严格不匹配;LocalDateTime.format()不输出时区因类型本身无时区;转Instant需先转LocalDateTime再指定时区;YYYY为周基年,yyyy为日历年,跨年场景易出错。
-
Java中易致内存泄漏的引用类型包括强引用(未置null或超作用域)、弱引用误用(如WeakHashMap中key未重写equals/hashCode)、静态集合滥用、内部类隐式引用、ThreadLocal未remove等。