-
JavaAgent必须在premain中调用instrumentation.addTransformer注册ClassFileTransformer才能生效,且需在MANIFEST.MF中声明Premain-Class和Can-Retransform-Classes;否则agent静默失效。
-
InvocationTargetException是反射调用异常的包装器,真实异常需通过getCause()获取;多层嵌套时应循环解包,推荐使用Spring的ExceptionUtils.unwrapInvocationTargetException()。
-
volatile失效并非语法失效,而是因误用(如循环缓存变量、误信字段可见性)或JIT将未观测的volatile读移出循环所致;排查需验证代码语义、JIT行为及运行时环境。
-
synchronized锁的是对象而非代码块或方法名,本质是给对象加监视器锁;实例方法锁this,静态方法锁类对象,同步代码块锁指定非null对象;锁自动获取释放,可重入但易因耗时操作拖长锁周期,JVM会按竞争动态升级锁。
-
本文详解Drools在Kubernetes微服务中因KieContainer非预期重复加载导致的MVELCompilationUnit内存堆积问题,涵盖诊断方法、典型误用模式、修复方案及云原生迁移建议。
-
Java15+使用三重双引号"""创建文本块,编译期语法糖,自动按最小公共缩进裁剪空格、保留源文件换行符,不支持嵌套和插值,需手动处理"""转义或拼接。
-
map将函数结果包装进Optional,flatMap要求函数返回Optional并自动展平一层,是避免嵌套Optional的唯一机制。
-
静态初始化适用于已知元素值的场景,如int[]arr={1,2,3};2.动态初始化用于运行时确定长度,如int[]arr=newint[5];3.声明与初始化可分离,提升灵活性;4.多维数组支持规则与不规则结构,如int[][]matrix={{1,2},{3,4}}或动态分配行列。
-
工厂模式通过解耦对象创建提升可维护性。简单工厂集中创建逻辑,适用于类型少的场景;工厂方法模式由子类决定实例化,符合开闭原则;抽象工厂用于创建相关产品族,支持复杂依赖。
-
Objects.equals能防NPE,因其内部先判空:二者同为null返回true,仅一者为null返回false,均非null才调用a.equals(b),彻底避免空指针异常。
-
父类构造方法中调用被子类重写的方法是危险但默认发生的多态行为;应避免在构造过程中依赖可被重写的行为,最稳妥方式是将方法设为final/sealed或推迟多态逻辑至构造完成后的显式初始化方法。
-
Math.abs()对Integer.MIN_VALUE返回负数是因补码取反溢出;应改用Math.abs((long)Integer.MIN_VALUE)或Math.absExact();Math.pow()性能差、精度低,小整数幂宜用乘法。
-
Java里用Observer接口写观察者模式,现在还行吗?不行。Java9开始java.util.Observer和java.util.Observable已被标记为@Deprecated,JDK14彻底移除。这不是“不推荐”,是“不能用”。官方弃用理由很实在:线程不安全、API设计僵硬、无法支持泛型。别再查老教程照搬Observable.notifyObservers()了。替代方案就一条路:自己定义观察者接口+主动通知逻辑。核心就两件事——谁发通知、谁收通知,中间不
-
ConcurrentLinkedQueue是Lock-Free而非Wait-Free,因其操作可能无限重试而无步数上界;Wait-Free要求每个线程有限步内必完成,Lock-Free仅保证系统整体有进展。
-
Java三元运算符类型提升由编译器按JLS§15.25计算两分支最小上界(LUB)决定,如int与Integer→int(触发拆箱),故flag?1:someInteger在someInteger为null时必NPE;应统一用包装类型或显式转型避免隐式拆箱。