-
Math.abs()对Integer.MIN_VALUE返回负数是因补码取反溢出;应改用Math.abs((long)Integer.MIN_VALUE)或Math.absExact();Math.pow()性能差、精度低,小整数幂宜用乘法。
-
Arrays.asList()返回固定长度List,不可增删;因其实现类未重写add/remove,调用抛UnsupportedOperationException;基本类型数组会被整体当作单个元素,应改用包装类型或Stream处理。
-
本文介绍如何在Java中通过正则表达式将字符串按空白字符(含空格、制表符、换行符等)分割,同时完整保留所有原始分隔符(如\n、\r\n、多个空格等),避免其被合并或丢失。
-
invokeSpecial指令直接绑定编译时确定的目标方法,绕过动态分派;MethodHandle无法真正模拟其语义,仅能通过findSpecial在合法访问范围内合规获取句柄,且必须指定声明类而非调用类。
-
确认Dubbo版本与SpringBoot兼容性用Dubbo做RPC,第一步不是写接口,而是看版本——dubbo-spring-cloud-starter和dubbo-spring-boot-starter不是同一套东西,混用会直接导致BeanCreationException:Errorcreatingbeanwithname'serviceBean'。SpringBoot2.4+默认禁用spring.factories自动装配,老版Dubbo(比如2.
-
CompressedClassSpace是JVM启用压缩指针时独立划分的固定大小内存区域(默认1G),专存Klass结构,不参与GC;耗尽即抛OutOfMemoryError:Compressedclassspace,与Metaspace是否充足无关。
-
Stream是惰性、只读的,不修改原集合;重复使用会抛IllegalStateException;collect需选对收集器;并行流慎用;空值和null须显式处理。
-
UUID.randomUUID()生成的是密码学安全的伪随机数,基于SecureRandom从操作系统熵源(如/dev/urandom)获取,非真随机但足够唯一和不可预测。
-
ArrayList.trimToSize仅收缩elementData数组容量,不触发GC,内存是否减少取决于冗余空间大小和GC时机;仅当size<elementData.length时生效,适用于一次性列表、筛选小结果等场景,需避免与subList共用。
-
不该直接用JDBC写增删改查,因其需手动管理连接、防空指针、拼SQL、处理异常与事务,易出错且难维护;MyBatis强调SQL优先,Hibernate强调对象优先,二者设计哲学相反,选错将导致返工。
-
ByteBuffer.wrap()不等于入池,它仅创建共享原数组的非池化HeapByteBuffer;真正入池需用Netty等框架的PooledByteBufAllocator分配并拷贝数据。
-
本文详解SpringBoot应用在JBossEAP/WildFly(如7.4)上通过JNDI复用服务器内置数据源的正确配置方式,重点解决因自动配置冲突导致的Failedtodetermineasuitabledriverclass启动失败问题。
-
CountDownLatch是Java并发包中用于让一个或多个线程等待其他线程完成一组操作的同步辅助类,适用于不关心返回值、只关注“全部执行完毕”信号的场景,如异步任务完成后统一日志汇总;初始化时指定等待的countDown()次数,需在任务启动前完成,每个任务必须在真正执行完毕(推荐finally块)调用countDown(),主线程通过await()阻塞等待,支持超时;它是一次性、无返回值、不处理中断的轻量同步工具,区别于CompletableFuture(需结果聚合)和CyclicBarrier(可
-
Condition的await()/signal()唤醒的是等待队列头部任意线程而非指定线程;交替执行靠多个Condition分离等待逻辑、while循环严格检查条件、修改状态后signal,且需正确处理中断。
-
在SpringBootJPA应用中,若尝试修改已持久化实体的复合主键(如num、date、typ)中的任意字段,JPA会抛出“identifierofanentitywasaltered”异常——因为主键在JPA生命周期中被视为不可变标识符。