-
向上转型是自动安全的子类→父类转换,向下转型需强制转换且必须实际类型匹配,否则抛ClassCastException;转换不改变对象本身,只改变引用视角。
-
HashSet判断重复需同时满足hashCode()相同且equals()返回true;仅用hashCode()会因哈希冲突导致误判;自定义类须重写二者,否则默认基于内存地址比较;底层基于HashMap实现,故支持null、不安全,且去重逻辑等同key去重。
-
final修饰基本类型变量时值不可变,修饰引用类型时仅锁住引用本身而非对象内容;final方法不可重写但可重载;final类不可被继承;final字段须在构造器结束前初始化,JVM为其提供内存屏障保障。
-
在Kotlin中,无需为ArrayList编写泛型类型检查扩展函数;直接使用as?安全类型转换操作符(如list[5]as?String)即可简洁、安全地实现运行时类型校验与空安全转换。
-
缓存组件核心是保证一致性、可控性、可观测性;需以接口抽象行为,组合TTL/TTI/主动失效/刷新机制,并内置穿透、击穿、雪崩防护,暴露统计、手动操作、加载器及序列化扩展能力。
-
Java分布式事务实现最终一致性的核心思路是异步与补偿。①基于消息队列的异步确保:通过本地事务保障业务操作与消息发送的一致性,结合定时任务重试机制和消费者幂等性处理,适用于大多数业务场景;②TCC模式:通过Try预留资源、Confirm确认、Cancel回滚三个阶段实现强一致性,但对业务侵入性强,适合金融支付等高一致性要求场景;③Saga模式:将长事务拆分为多个本地短事务并配补偿操作,适用于复杂服务链,可选编排式(集中控制流程)或协调式(事件驱动),前者适合复杂流程便于维护,后者去中心化适合简单固定流程。
-
Java内存划分为栈和堆,核心是兼顾执行效率与灵活性:栈管理方法执行(存基本类型、引用、调用现场),生命周期短、释放快;堆管理对象存储(动态分配、GC回收),生命周期长、支持共享。
-
记账工具核心实体为Account、Transaction、Category三类;Transaction金额必须用BigDecimal并禁用基本运算符;持久化推荐Jackson序列化RecordBook至JSON;交互采用编号菜单与输入校验;务必重写toString()和equals()。
-
Java项目集成Swagger可自动生成API文档,提升开发效率。1.SpringBoot2.x可使用Springfox,需添加依赖并配置@EnableSwagger2及DocketBean,访问/swagger-ui.html查看文档;2.SpringBoot3+推荐使用SpringDoc,引入springdoc-openapi-starter-webmvc-ui依赖即可自动集成,无需额外配置,访问/swagger-ui/index.html;3.通过@Tag、@Operation、@Parameter
-
本文介绍一种轻量级、无额外集合开销的方案,通过保存上一次输入的对象状态,在每次调用func()时实时比较当前与前一次电池值的差值;若绝对差大于1,则输出前一次的电池值及对应时间。适用于高频调用(如上千次)且内存敏感的场景。
-
统一Java开发环境的核心是建立可复现、可协作、可交付的一致性基础,关键在于通过JDK版本锁定、项目级构建配置、IDE配置版本化及容器化初始化,确保任何人拉代码即可编译运行且行为一致。
-
CountDownLatch通过计数器实现线程等待,初始化指定数量,调用countDown()减一,await()阻塞至计数为零,适用于主线程等待多个任务完成的场景。
-
for-each遍历时调用remove()会抛ConcurrentModificationException,因modCount与expectedModCount不一致;正确做法是用Iterator.remove()、removeIf()或倒序for循环。
-
类是模板,对象是用new创建的具体实例;类不占内存、不能执行方法,仅描述结构,真正存储数据和执行行为的是对象,每个对象拥有独立字段值,静态成员除外。
-
Collectors.summarizingLong用于提取流中元素的long值并生成包含计数、总和、最值和平均值的LongSummaryStatistics对象,适用于需一次性获取多项统计指标的场景。