-
ClassNotFoundException是类未被加载,发生在类加载的查找阶段;NoClassDefFoundError是类曾加载但初始化失败,后续引用时抛出。二者根本区别在于:前者是“找不到”,后者是“找得到但用不了”。
-
Log4j2依赖需同时引入log4j-api和log4j-core,否则运行时报错;配置文件log4j2.xml须置于src/main/resources下且命名准确;RootLogger级别与Appender绑定必须正确;多模块中可用log4j2.component.properties指定配置优先加载。
-
Java集合判断对象相等需同时重写equals()和hashCode(),因先用hashCode()定位桶再用equals()确认;若只重写equals(),逻辑相等的对象可能被散列到不同桶,导致重复添加、查找失败等问题。
-
Scanner输入卡住因nextInt()不读换行符,导致nextLine()读空行;应统一用nextLine()后转换,或在nextInt()后加nextLine()清缓存;BMI用double足够,Math.round四舍五入;if-else需按BMI区间升序判断;文件写入推荐Files.write()避免乱码和资源泄漏。
-
java-version是最可靠的Java安装验证方式,它不依赖IDE或项目配置,只检验系统能否调用java可执行文件;输出包含版本号、JDK类型、架构和运行时信息,且能暴露PATH与JAVA_HOME不一致等问题。
-
Field.getType()返回字段声明时的原始类型(如List.class),不包含泛型信息,也不反映运行时实际对象类型;需用getGenericType()获取泛型参数,用value.getClass()获取运行时类型。
-
Java动态代理是在运行时通过InvocationHandler和Proxy类自动生成代理对象,以实现在不修改原有代码的情况下增强方法功能。其核心在于:1.InvocationHandler接口负责处理代理对象的方法调用,通过invoke方法拦截并插入前置、后置及异常处理逻辑;2.Proxy类用于动态生成代理实例,通过newProxyInstance方法结合类加载器、接口列表和InvocationHandler实例创建代理对象;3.动态代理解决了静态代理的代码冗余、维护困难和扩展性差的问题,适用于统一处理
-
JVM内存管理需精细调优而非依赖自动回收:堆分代模型(新生代/老年代)、System.gc()仅为建议、Metaspace泄漏隐蔽性强,四者不匹配易致OOM或卡顿。
-
首先导入java.util.Scanner并创建Scanner对象读取键盘输入;2.使用nextLine()、nextInt()等方法获取不同类型数据;3.注意nextInt后需调用nextLine吸收回车符,避免输入跳过;4.输入完成后调用close()释放资源;5.处理类型不匹配异常确保程序健壮性。
-
invokevirtual是Java多态的运行时执行指令,根据对象实际类型查虚方法表(vtable)动态分派;编译期仅做符号解析,不决定具体实现。
-
私有化属性并通过getter/setter方法控制访问,能有效保护数据完整性。在Java中,使用private修饰字段(如name、age)可防止外部直接访问,确保只能通过类提供的公共方法进行读写。例如,在setAge方法中可加入年龄非负的校验逻辑,避免非法赋值,从而实现安全的状态管理与封装。
-
通过注册ShutdownHook可在JVM关闭前执行资源释放;2.正确关闭线程池需调用shutdown()并配合awaitTermination()等待任务完成;3.结合volatile标志位可实现主线程在收到中断信号后完成当前任务再退出;4.避免重复添加hook、禁止在hook中调用System.exit(),确保关闭操作幂等;5.Web应用应结合容器生命周期管理。合理使用这些方法能保障Java程序安全退出,防止资源泄漏和数据丢失。
-
Java反射访问私有字段必须调用setAccessible(true),否则get()/set()抛IllegalAccessException;需用getDeclaredField()获取字段,静态字段get()传null,实例字段传对象;模块系统下可能抛InaccessibleObjectException。
-
双亲委派模型通过父优先加载机制防止类重复加载和类型冲突,确保核心类由BootstrapClassLoader加载;JDBC等场景需借助上下文类加载器破坏委派;自定义类加载器应重写findClass而非loadClass;Java9+模块系统削弱了传统双亲委派结构。
-
方法描述符是JVM中唯一标识方法的紧凑字符串,如(I)Z,用于区分重载、动态调用和类型验证;它与MethodType语义相近但用途分离,前者用于字节码操作,后者用于MethodHandle运行时分派。