-
答案:封装通过private字段和getter/setter保护数据,继承使子类复用并扩展父类功能,多态通过方法重写实现同一接口不同行为。示例中Animal类封装name和age,Dog和Cat继承Animal并重写makeSound方法,TestAnimals中父类引用指向子类对象,运行时动态调用对应方法,体现多态性。三者结合提升代码安全性、复用性与扩展性。
-
Arrays.asList()返回的是不可增删的内部类,仅支持set修改原数组;需newArrayList<>(Arrays.asList(arr))获得可变集合;基本类型数组须用Stream.boxed()转换。
-
Java遍历数组主要有传统for循环、增强for循环、StreamAPI和迭代器四种方式:需索引或修改元素用传统for;简单遍历优选增强for;过滤转换用Stream;引用类型数组需边遍历边安全删除时才用Arrays.asList+迭代器。
-
StackOverflowError是JVM运行时错误,因线程调用栈深度超限导致;常见于无终止条件的递归、隐式循环调用或toString等方法中自引用;典型特征是堆栈跟踪大量重复行;解决需修复逻辑而非盲目调大-Xss。
-
Java编程六大常见错误:①局部变量未初始化即使用;②混淆==与equals()导致字符串比较错误;③循环中直接修改集合引发ConcurrentModificationException;④异常处理不完整,如忽略检查型异常或空catch;⑤循环内用+拼接字符串致性能下降;⑥未区分成员变量默认值隐患。
-
Java中不能强制停止线程,唯一推荐方式是通过中断机制协作式通知;调用interrupt()仅设置中断状态为true,线程需主动检查并安全退出,禁用已废弃的stop()等方法。
-
在Java中处理金融或货币计算时,直接使用double或float会因二进制表示误差导致精度问题,必须改用BigDecimal。1.BigDecimal通过字符串或BigInteger实现任意精度十进制运算,避免浮点数的天然缺陷;2.创建时应避免使用double参数构造函数,推荐用String或BigDecimal.valueOf(double);3.运算不可变,每次操作需赋值新对象;4.除法必须指定scale和RoundingMode,否则可能抛异常;5.比较数值应使用compareTo()而非equa
-
选IntelliJIDEA,因其对Java生态深度集成——如javac错误内联标红、Maven自动重载、Lombok零配置识别;SpringBoot原生支持、热更新能力更强、重构更安全;Eclipse仅在特定老项目、Ant构建或定制插件场景下更优。
-
Java数组初始化有三种方式:一是声明并直接初始化(如int[]nums={1,2,3}),须同行完成;二是先声明后用new创建(如int[]arr;arr=newint[5]);三是声明+new+初始化合并(如int[]data=newint[]{1,2,3}),二维数组同理。
-
封装通过private修饰属性并提供public的getter和setter方法实现,如Person类中name和age私有化后,通过getName、setName等方法安全访问,并可在setAge中添加年龄校验逻辑。
-
答案是:==比较值或内存地址,equals()比较逻辑内容,重写equals()需遵守五契约并同步重写hashCode()。
-
DelayQueue是Java中基于优先级队列实现的无界阻塞延时队列,要求元素实现Delayed接口(含getDelay和compareTo方法),仅到期任务可被take()获取,需配合外部线程消费,适用于单次延时场景如订单关单。
-
ABA问题指值从A变为B再变回A,导致CAS误判未变化,从而引发数据不一致;AtomicStampedReference通过引入版本戳,在每次修改时更新戳值,即使引用值恢复为A,戳的变化也能表明实际发生过修改,从而解决该问题。
-
Java中用户操作偏好持久化需按场景选择策略:桌面端用PreferencesAPI,Web端用Session+数据库,结构化存储推荐JSON或Properties,并注意生命周期管理与默认值兜底。
-
Java配置中心核心是动态推配与用配联动,含存储层、服务端和客户端SDK三部分;SpringBoot中可用@ConfigurationProperties+@RefreshScope配合/actuator/refresh实现动态加载,需避坑@Value不刷新、类型转换静默失败等问题。