-
jstat-gcutil可实时监控FullGC后老年代内存是否真实释放,关键看OU是否明显下降;若OU降幅极小或快速回升,则可能存在内存泄漏。
-
矩阵转置在报表系统中需用嵌套循环实现行列动态互换,关键在于预处理非规整数据、采用连续内存优化性能、分离数据存储与视图映射,并分别处理数值与文本以应对空值和类型混合。
-
高并发下应避免synchronized全局锁,因其导致请求串行化、吞吐量骤降,并易引发线程饥饿或死锁;优先使用AtomicInteger、ReentrantLock(带超时)、ConcurrentHashMap等并发工具。
-
JavaNIO的Channel是双向非阻塞的,必须配合Buffer使用,需正确调用flip()、clear()等方法管理position/limit/capacity;FileChannel支持随机定位,SocketChannel不支持;Selector要求Channel必须非阻塞,且close()与wakeup()存在线程安全依赖。
-
重写equals后必须重写hashCode,否则在HashMap、HashSet中会出现查找失败、重复添加等问题;根本原因是Java规范要求equals为true时hashCode必须相等,且应使用Objects.hash()包含所有equals中参与比较的字段并保持顺序一致。
-
浅克隆复制对象但共享引用,适用于简单结构或性能优先场景;深克隆递归复制所有引用对象,适用于需完全隔离的可变复杂结构,选择依据是是否允许引用共享。
-
Log4j2配置需放src/main/resources/log4j2.xml,Maven中排除Log4j1并引入log4j-api和log4j-core;SLF4J+Logback需避免绑定冲突,仅保留slf4j-api和logback-classic;Logback滚动策略应配置SizeAndTimeBasedRollingPolicy并设maxHistory与totalSizeCap;生产日志失效多因profile未激活、权限不足或配置路径错误。
-
LinkedList默认实现Deque接口,天然支持双端队列操作;addFirst/offerFirst等方法区别在于异常策略与返回值;空时调用removeFirst会抛NoSuchElementException,应优先用pollFirst;纯双端队列场景下ArrayDeque性能更优但不支持null。
-
增强for循环编译后等价于传统for+数组访问,对原生数组性能无差异;但遍历集合时需创建Iterator对象,有额外开销;传统for支持索引操作,适用跳过元素、相邻访问等场景。
-
本文揭示了快速排序实现中常见的递归调用错误:原代码错误地将子问题划分为[first,last−1]和[first+1,last],导致无限递归和性能崩溃;正确做法是按基准位置pivot划分区间为[first,pivot−1]和[pivot+1,last]。
-
MySQLJDBC驱动应选mysql-connector-j8.0.33+(JDK17+需8.3.0+),适配MySQL8.0+的caching_sha2_password认证,Maven声明scope为runtime,URL须含useSSL=false、serverTimezone=UTC和allowPublicKeyRetrieval=true。
-
java.util.logging可快速启用基础日志,但需显式添加ConsoleHandler并设级别;捕获异常应使用log(Level,msg,throwable)保留堆栈;FileHandler需设append=true防覆盖;生产推荐Log4j2替代。
-
Java匿名内部类必须用new和{}定义,本质是编译生成的独立类文件,仅能继承一个类或实现一个接口,可访问外部final变量,但易致内存泄漏,Lambda仅适用于函数式接口。
-
快速幂本身无需数组,但可预存a^(2ⁱ)modm的中间结果于数组中以支持多次查询;数组按i索引存2ⁱ次幂值,预处理O(logn),每次查询O(logn)查表相乘。
-
Method.invoke()调用失败的常见报错和原因直接调用Method.invoke()报IllegalAccessException或IllegalArgumentException,基本是权限或参数没对齐。Java反射默认不绕过访问控制,private方法必须先setAccessible(true);而参数类型不匹配(比如传了int却期望Integer)会触发IllegalArgumentException,哪怕看起来“值一样”。静态方法调用时,invoke()第