-
HashSet底层基于HashMap实现,元素作为key存储,value统一为PRESENT对象;依赖HashMap的key唯一性保证元素不重复,需重写equals和hashCode;非线程安全,支持初始容量和加载因子配置,默认16容量、0.75加载因子;不保证插入顺序,有序需求用LinkedHashSet,排序需求用TreeSet。
-
静态方法中不能使用this,因为this指向具体对象实例,而静态方法属于类本身、无需实例即可调用,其字节码签名不含this参数,编译期即被禁止。
-
TreeSet不能存null,因其底层依赖compareTo()或Comparator.compare()排序,而null调用这些方法会抛NullPointerException;HashMap允许key为null(仅一个)和任意value为null,ConcurrentHashMap则禁止null作为key或value。
-
Java内存模型中的可见性指线程修改共享变量后其他线程能否及时看到新值,根本原因在于JMM将变量存于主内存而线程操作工作内存副本,且同步无强制时机;volatile通过强制读写主内存解决可见性,但不保证原子性;synchronized等锁机制也通过happens-before规则保障可见性。
-
ByteArrayInputStream是Java中以字节数组为源的轻量级输入流,适用于单元测试、内存解析二进制协议或序列化数据消费;不复制数组、不支持真正重置、非线程安全,慎用于共享或可变数组场景。
-
用<<移位打包颜色通道是图像像素处理中最常用、最轻量的方式,因其直接映射CPU指令、无类型转换风险、语义清晰且比乘法更快更可靠。
-
Record类的equals和hashCode是编译器按契约自动生成的底层行为:基于值语义逐字段比较、严格依赖字段声明顺序、由不可变性保障哈希稳定性,三者共同确保符合Object规范且不可绕过。
-
Unsafe.allocateMemory绕过GC需配对freeMemory,否则内存泄漏或崩溃;putX/getX无边界检查易越界;禁混用DirectByteBuffer地址;新项目应优先使用MemorySegment+VarHandles。
-
getClass()返回代理对象实际运行时类型(如$Proxy1),无法直接获取目标类;需通过Proxy.getInvocationHandler()获取处理器,再反射提取其内部目标对象getClass()才能得到原始业务类。
-
接口常量适用于多类共用、极少变更的基础配置和语义锚点,须严格遵循命名规范、分层定义位置,并通过接口名直接引用。
-
DatagramSocket无需connect()即可发包,发送目标由DatagramPacket携带,必须用含地址和端口的四参构造器;receive()需设超时避免阻塞,bind()前应调用setReuseAddress(true)解决端口占用。
-
优先选AVL树适用于高频读取、低频更新场景,如配置中心;红黑树更适配读写均衡或写多于读的动态场景,如实时交易系统,且工程实现与生态支持更优。
-
Map的key必须重写equals()和hashCode(),因哈希表靠hashCode()定位桶、equals()判断键等价;若不重写,默认地址比较会导致相同逻辑对象被误判为不同key。
-
高位泄漏指高优先级线程因上下文错置长期持有TraceContext/Span/MDC,导致内存增长、GC压力升高等问题;本质是ThreadLocal强引用锁死引发的带业务语义泄漏。
-
ConcurrentHashMap在JDK1.8后采用CAS+synchronized实现线程安全,以Node数组+链表/红黑树结构提升并发性能,通过synchronized锁单个桶节点实现细粒度控制,允许多线程在不同桶上并发写入,仅在哈希冲突时竞争,显著提高吞吐量;推荐使用putIfAbsent、computeIfAbsent、merge等原子方法避免显式同步,合理设置初始容量和并发等级以减少扩容开销,并注意复合操作需用内置方法保证原子性,防止竞态条件。