-
购物车用ArrayList<CartItem>而非HashMap,因需保留价格、规格等上下文;库存校验先用内存Map模拟再替换为DAO;订单状态用enum+switch限制合法迁移路径。
-
重写必须发生在父子类间且方法签名完全一致,是运行时多态基础;重载仅限同一类中参数列表不同,属编译时静态绑定。
-
在使用Lombok的@Builder注解处理泛型类(如Response<T>)时,Java类型推断无法自动识别链式调用中的具体类型参数,需通过显式类型见证(typewitness)如Response.<Article>builder()来指定泛型类型,否则编译失败。
-
装箱是基本类型转包装类,拆箱反之;Java5起支持自动装箱/拆箱,编译器自动转换,简化代码但可能引发性能问题、空指针异常和比较陷阱,需注意集合操作、参数传递等场景中的隐式转换风险。
-
注解是Java中为代码添加元数据的标签机制,用于描述程序元素的额外信息,如@Override确保方法重写正确,@Deprecated标记过时代码。编译器或框架可读取这些信息执行相应操作,例如Spring通过@Controller、@Autowired等注解实现依赖注入和控制器注册,替代繁琐的XML配置。开发者还可自定义注解并结合反射在运行时动态处理,实现日志、权限校验等功能。注解的生命周期由@Retention策略控制,其中RetentionPolicy.RUNTIME保留至运行时,支持反射访问,是框架实
-
Java并发集合通过分段锁、CAS、不可变快照等机制实现线程安全与高性能,支持原子复合操作,适配不同读写场景,但不保证跨操作业务逻辑的原子性。
-
Java正则需用Pattern.compile()预编译复用,避免字符串matches()重复编译;注意DOTALL与UNICODE_CHARACTER_CLASS组合使用、Unicode匹配需(?U)或显式标志;基础校验优先用EmailValidator等专用工具,正则仅作初步筛选。
-
守护线程会在主线程退出时被强制终止,不保证执行完;JVM仅等待非守护线程结束,守护线程可能被立即杀死,不执行finally、shutdownhooks或资源释放逻辑。
-
Java接口默认方法是Java8引入的用default关键字定义的有具体实现的方法,用于解决接口升级时的向后兼容问题,如Collection新增stream()方法而不强制修改所有实现类。
-
ClassNotFoundException表示JVM运行时找不到指定类,常见于反射、动态加载等场景;核心原因是类路径缺失或ClassLoader隔离,需检查打包内容、依赖范围、类加载器委托及混淆/模块化配置。
-
volatile解决多线程内存可见性问题,保证写操作立即刷回主存、读操作强制从主存获取,但不保证原子性与互斥,适用于独立布尔标志或状态开关等场景。
-
OOP通过封装、继承和多态提升代码复用性与可维护性,适合大型项目扩展与团队协作,但存在性能开销、继承复杂性和设计冗余等问题,在并发编程和数据处理场景中逐渐显现出局限,需结合函数式等范式以应对多样需求。
-
分层异常处理的核心是按职责隔离异常:表现层只暴露用户友好的提示,业务层用语义化异常表达规则(如InsufficientStockException),数据访问层将技术异常统一包装为DataAccessException。
-
Java中Set的唯一性依赖equals()和hashCode()的正确实现:HashSet用哈希表存储,通过hashCode()定位桶、equals()判重;TreeSet用排序比较;自定义类需同时重写二者并保持一致性,且推荐不可变设计。
-
给定一组人员及两个工具函数(获取某人所属的组、获取某组包含的人员),需快速找出所有成员均在输入人员列表中的朋友组,避免低效的嵌套遍历与重复检查。