-
扩容无需重算hash值,因容量恒为2的幂次方,新索引仅取决于原hash在新增bit位的值;JDK1.8用e.hash&oldCap快速提取该位,0则留原索引,非0则原索引+oldCap。
-
POJO是无框架依赖的普通Java对象,非角色而是设计状态;DTO用于跨层数据传输,VO专用于视图渲染;Entity绝不直接返回前端,需通过DTO/VO转换隔离。
-
最稳妥的方式是使用NumberFormat.getCurrencyInstance()并显式传入目标Locale(如Locale.CHINA),配合BigDecimal精确计算,避免double精度问题和Locale默认值陷阱。
-
单例模式在Java中有6种常见实现方式,各有适用场景。1.饿汉式:类加载时即创建实例,线程安全但不支持延迟加载,适合性能要求高、创建成本低的对象;2.懒汉式:首次调用时创建,需加锁保证线程安全,适合并发不高场景;3.双重检查锁定:仅首次创建时加锁,结合volatile关键字防止重排序,兼顾性能与安全,广泛采用;4.静态内部类:利用类加载机制实现线程安全延迟加载,推荐使用;5.枚举方式:语法简洁,天然防反射和反序列化破坏单例,适合不介意枚举写法的情况;6.容器或Spring框架管理:通过@Component
-
对象初始化按内存分配、字段默认初始化、显式初始化和构造方法执行的顺序进行,确保实例状态正确;通过new创建对象后,使用对象名.方法名调用实例方法,支持多态;合理设计构造方法可提升安全性与代码复用,避免在构造器中调用可重写方法;静态方法通过类名调用,不依赖实例;推荐先初始化再调用,结合构造器或初始化块处理共用逻辑,保证程序稳定。
-
增强for循环无法修改ArrayList元素值或结构。因其获取的是元素副本引用,对循环变量赋值不影响原集合;修改对象内部状态(如StringBuilder.append)有效,但替换引用无效;结构性修改需用Iterator.remove()或倒序for循环。
-
System.console()在IDE中返回null是因缺乏底层TTY支持,仅在系统终端运行jar时有效;readPassword()返回char[]为安全设计,需手动清零;Windows中文路径会导致编码问题;多环境部署应放弃该API,改用适配方案。
-
putIfAbsent能避免覆盖已有数据,因为它仅在key不存在或对应value为null时才插入新值,且是原子操作;但HashMap版非线程安全,多线程须用ConcurrentHashMap,并确保value非null以防误判。
-
内部类能访问外部类私有成员,是因为编译器自动生成package-private合成方法(如access$000)并隐式添加外部类引用this$0,所有访问均通过这些合成方法间接完成,JVM层面无特殊豁免。
-
IntelliJIDEADebug时需在运行配置中设置:Programarguments填命令行参数,Redirectinputfrom留空,并勾选Interactivemode;Eclipse需勾选AllocateConsole和Connectprocessinputtoconsole;VSCode需设"console":"integratedTerminal"。
-
module-info.java是模块强制入口文件,须置于源码根目录且命名规范;exports解决包可见性,opens才支持反射访问私有成员;混用模块路径与类路径会生成不可控的自动模块。
-
Thread.stop()被弃用是因为它强行注入ThreadDeath异常,破坏锁状态与对象一致性,导致中间态暴露和逻辑损坏;安全停止应依赖volatile标志与interrupt()协作退出。
-
Windows安装Java开发环境需安装JDK(如JDK17/21)并正确配置JAVA_HOME与Path变量,路径须无中文和空格,验证java-version和javac-version均有效。
-
Java黑名单机制核心是“拦截+校验+持久化”,应置于请求进入业务逻辑前(如Web层Interceptor、RPC层Filter、服务内敏感操作前),避免DAO层硬编码;存储依规模与实时性选型。
-
使用update-alternatives可管理多JDK版本,1.查看配置状态,2.添加JDK路径并设置优先级,3.交互式切换版本,4.验证java-version,实现灵活切换。