-
Java中抛出异常的核心是:用throw抛出异常实例,用throws声明受检异常;未捕获的受检异常必须声明,否则编译失败;运行时异常无需声明。
-
封装的核心是约束与责任划分,通过私有化字段并提供公共方法控制访问,确保对象始终处于合法状态,如用户余额需由账户对象自身管理增减操作。
-
答案:使用SDKMAN可便捷管理多版本JDK。先通过curl命令安装SDKMAN,加载初始化脚本后运行sdkversion验证;执行sdklistjava查看可用JDK版本;用sdkinstalljava[版本号]安装指定JDK,如17.0.2-amzn;通过sdkusejava临时切换版本,或sdkdefaultjava设为默认;最后java-version确认当前版本。整个过程自动配置环境变量,无需手动干预,适合多项目开发与兼容性测试。
-
在Java面向对象编程中,构造器用于创建对象时初始化其核心属性,而setter方法则用于对象创建后动态修改可变属性;二者职责分明,合理选择能提升代码的健壮性与可维护性。
-
Java统一异常处理核心是@ControllerAdvice配合@ExceptionHandler,结合统一响应格式Result<T>和分级日志记录,实现异常拦截、分类处理与友好返回。
-
Map与Collection是Java集合框架中并列的顶层接口,无继承关系;Map存储键值对且key唯一,不实现Iterable,故不能直接用增强for循环遍历;其keySet()返回Set,values()返回Collection(因value可重复),entrySet()返回Set<Map.Entry>;Collections工具类方法不适用于Map,需用ConcurrentHashMap或Collections.synchronizedMap()等专用方式实现线程安全。
-
Condition是Java中用于线程协作的接口,需与Lock配合使用,支持多条件等待和精确唤醒;示例中通过notFull和notEmpty两个Condition实现生产者-消费者模型,相比synchronized+wait/notify,具备可中断、超时等待及更灵活的锁控制优势。
-
final的核心作用是“禁止修改”,用于明确设计意图、提升安全性与可维护性:修饰类则禁止继承,修饰方法则禁止重写,修饰变量则禁止重新赋值。
-
观察者模式通过被观察者状态变化时自动通知所有依赖的观察者实现一对多更新,常用于事件处理、GUI交互与数据同步;核心为Subject维护Observer列表并触发update方法,Java中可通过自定义接口或过时的Observable类实现,适用于解耦事件源与处理逻辑,需注意性能与内存泄漏问题。
-
Java类初始化仅在五种主动引用场景下触发:new实例、访问/修改非final静态字段、调用静态方法、反射Class.forName()、初始化子类时;主类启动时也必初始化;被动引用如子类引用父类静态字段、定义数组、引用编译期常量则不触发。
-
捕获Exception本身不是坏习惯,但不加区分地捕获会掩盖编程错误、干扰异常语义、误吞关键异常并导致日志失真;应优先捕获具体异常,仅在顶层兜底或特殊场景下谨慎使用。
-
Java字节码是JVM可执行的二进制指令集,存于.class文件中,以魔数0xCAFEBABE开头,含版本号、常量池、字段方法表等严格结构;由javac编译生成,可用javap或jclasslib查看;JVM通过解释器或JIT执行,基于栈设计,兼顾跨平台与效率。
-
Java8允许接口定义默认和静态方法。1.默认方法用default修饰,可提供实现且不强制子类重写,支持接口演进与多继承行为;2.静态方法用static修饰,通过接口名调用,用于工具函数;3.类实现多个含相同默认方法的接口时需显式重写以解决冲突;4.默认方法可被重写并能访问抽象方法,静态方法不可重写也不能访问实例成员。这一改进使接口更具扩展性,便于集合框架等大型API升级,同时促进函数式编程支持,提升代码复用与维护性。
-
CLASSPATH不必须配置,但不配易出NoClassDefFoundError;JVM默认加载当前目录,外部JAR、多模块等场景需显式指定,且-cp优先级最高、覆盖CLASSPATH和默认.。
-
双引号创建的字符串自动入池,new创建的对象不入池;通过intern()可手动入池,提升重复字符串处理性能,但需注意内存管理。