-
装箱是基本类型转包装类,拆箱反之;Java5起支持自动装箱/拆箱,编译器自动转换,简化代码但可能引发性能问题、空指针异常和比较陷阱,需注意集合操作、参数传递等场景中的隐式转换风险。
-
必须安装JDK而非JRE,并正确配置JAVA_HOME环境变量;用记事本写代码、命令行编译运行;注意类名与文件名一致、javac/java版本匹配、源文件编码为UTF-8。
-
不能。JVM不自动检测或解除死锁,ThreadMXBean.findDeadlockedThreads()仅诊断并返回死锁线程ID列表,不终止线程;需人工干预或预防,且仅检测synchronized锁,不覆盖ReentrantLock等显式锁。
-
Java异常默认自动向上抛出:未捕获的checked异常需声明throws,unchecked异常可直接冒泡;传播由JVM自动完成,无需手动throw;吞掉异常或丢失堆栈是常见错误。
-
重写findClass方法是为了在不破坏双亲委派模型的前提下实现自定义类加载逻辑,如从网络、数据库或加密文件加载字节码,并通过defineClass将字节码转为Class对象。
-
本文详解Java中--x与x+--x等混合表达式的执行逻辑,揭示看似矛盾的输出(如7和6)实则源于操作数求值顺序(从左到右)与副作用发生的时序,而非单纯依赖运算符优先级。
-
Java分布式事务实现最终一致性的核心思路是异步与补偿。①基于消息队列的异步确保:通过本地事务保障业务操作与消息发送的一致性,结合定时任务重试机制和消费者幂等性处理,适用于大多数业务场景;②TCC模式:通过Try预留资源、Confirm确认、Cancel回滚三个阶段实现强一致性,但对业务侵入性强,适合金融支付等高一致性要求场景;③Saga模式:将长事务拆分为多个本地短事务并配补偿操作,适用于复杂服务链,可选编排式(集中控制流程)或协调式(事件驱动),前者适合复杂流程便于维护,后者去中心化适合简单固定流程。
-
审批模板核心结构包含三部分:审批节点定义、流转规则、状态管理;节点用POJO定义并支持动态处理人,流转通过策略+责任链实现配置驱动,状态变更由受控枚举方法保障合法性。
-
用审计字段+历史表实现可追溯:主表加created_by/created_time/updated_by/updated_time四字段,历史表存操作类型、前后JSON数据、操作人及时机;Service层统一拦截记录,查询时对比差异返回变更字段。
-
JUC不是替代老式同步机制,而是通过高级抽象解决并发场景的可扩展性、可靠性与开发效率问题:提供ReentrantLock、Condition等语义明确工具,线程安全集合,ExecutorService任务调度,以及Atomic原子类和StampedLock等无锁编程支持。
-
本文解释为何使用增强for循环配合indexOf()会导致计数变量numberPositive无法正常递增,并提供基于索引的安全遍历方案,同时指出边界风险与修复建议。
-
答案:Java中多维数组是“数组的数组”,常用二维数组,支持声明时指定维度或使用不规则数组;可通过嵌套循环遍历,推荐增强for循环;常见操作包括复制(注意深拷贝)、查找极值、矩阵转置及用List替代实现动态扩容;需注意索引越界和空引用问题。
-
Java方法由访问修饰符、返回类型、方法名、参数列表和方法体构成;无参方法执行固定行为,带参方法提升复用性;void方法可省略return,非void方法每条路径须有return;实例方法通过对象调用,静态方法通过类名调用。
-
答案是通过命令行输入echo%JAVA_HOME%(Windows)或echo$JAVA_HOME(macOS/Linux),若输出为JDK安装路径则设置正确;检查方法因系统而异,Windows可通过系统属性查看环境变量,macOS/Linux需查看shell配置文件;JAVA_HOME指向JDK根目录,用于确保开发工具能统一找到Java开发环境;若设置错误,可能导致javac无法使用、Maven或IDE找不到SDK等问题;修正时需在系统变量或shell配置中设置正确的JDK路径,并将%JAVA_HOME
-
ScheduledExecutorService优于Timer因其线程池机制可隔离异常、支持并行,且提供scheduleAtFixedRate(固定周期)与scheduleWithFixedDelay(执行完再延迟)两种调度策略,任务类型支持Runnable和Callable,关闭时需合理调用shutdown()与awaitTermination()等方法。