-
new是Java创建对象最直接可控的方式,触发完整生命周期:分配内存→初始化字段→执行构造方法→返回引用;需注意语法规范、异常处理及构造方法逻辑完整性。
-
Fastjson1.2.68+默认禁用autoType引发拒绝或ClassNotFoundException,需显式白名单开启;Jackson静默失败因字段不可见或无参构造器缺失;日期格式、并发性能差异需统一配置与复用实例。
-
可用removeAll和retainAll提取增删元素:新增为newArrayList(listB).removeAll(listA),删除为newArrayList(listA).removeAll(listB);需注意保序、避副作用、处理重复元素及类型可比性。
-
Java接口支持多重继承,类仅支持单继承。通过extends关键字可使接口继承多个接口,用逗号分隔,如interfaceCextendsA,B;实现类必须实现所有继承的抽象方法,否则需声明为抽象类;当父接口存在同名同参方法时视为同一方法,实现一次即可;若默认方法冲突,子接口或实现类必须显式重写以解决歧义。该机制提升代码复用与灵活性,但需注意方法冲突处理。
-
Integer.valueOf()在-128~127范围返回缓存实例,超范围才new;自动装箱调用valueOf,拆箱调用intValue();null调用intValue()抛NPE,需判空;缓存边界与空安全是高频陷阱。
-
Java数组的length是编译期确定的final字段而非方法,因数组为JVM内置类型,大小固定且存于对象头中;调用length()、对null数组访问或混淆List.size()均会报错。
-
复制算法提升Survivor区空间利用率的核心是高效回收与合理分配,通过控制对象存活率、优化复制节奏、动态调整区大小来减少碎片和避免提前晋升。
-
throw用于方法体内实际抛出异常对象并中断执行,throws用于方法声明末尾声明可能抛出的异常类型以告知调用者;前者后接异常实例,后者后接异常类名,可多个逗号分隔。
-
本文详解在Liferay7.x+Tomcat环境下,为何无法找到传统WAR文件,并阐明其基于OSGi的新型部署机制,指导开发者正确更新SDK依赖。
-
Java泛型是编译期类型检查机制,非语法糖;擦除后运行时无泛型信息,故禁用newT()、instanceofT、T.class及泛型异常捕获。
-
Java项目在Eclipse中需三处统一设为UTF-8:项目级Textfileencoding(右键项目→Properties→Resource)、工作空间全局编码(Window→Preferences→Workspace)、Maven的project.build.sourceEncoding;否则中文注释、文件读写、编译均可能乱码。
-
静态导入是Java5引入的特性,用于直接导入类的静态成员以省略类名前缀;支持导入指定成员或通配符导入所有静态成员,但后者易引发命名冲突;适用于单元测试、数学计算和集合工具操作等场景,需避免滥用影响可维护性。
-
super是编译期确定的直接父类成员访问入口,不触发多态、不绕过访问控制;调用构造器须首行且唯一;访问字段和方法均为静态绑定;内部类中A.super特指外围类方法调用。
-
Java中ExecutorService需通过Executors工厂方法或手动构建ThreadPoolExecutor创建;常用方式包括newFixedThreadPool(固定线程数、无界队列)、newSingleThreadExecutor(单线程串行)、newCachedThreadPool(弹性线程、SynchronousQueue)和newScheduledThreadPool(定时任务);自Java9起推荐显式构造ThreadPoolExecutor以控制参数。
-
MyBatisXML修改不生效主因是未启用热加载,需引入mybatis-spring-boot-devtools插件并配置enable:true,确保XML路径匹配、文件名与接口名一致,且避免手动定义SqlSessionFactory或跨文件include。