-
适合,HashedWheelTimer专为高并发连接的超时调度设计,适用于数万路TCP连接的3s~2min级断线检测与重传,但精度受限于tickDuration(如100ms),且需显式cancel避免内存泄漏。
-
成员变量绝大多数情况下应使用private+final修饰,以保障封装性和不可变性;仅在特定场景(如子类需修改、常量、临时缓存)可例外,但须严格遵循规范。
-
charAt()越界会抛StringIndexOutOfBoundsException;String底层是char[]但不暴露,取字符必须用charAt(),调用前需检查index>=0&&index<length()。
-
main方法必须用static修饰,因为JVM启动时尚未创建任何对象,需直接通过类名调用入口方法;static方法属类级别,随类加载即就绪,无需实例、this或参数,符合“类加载→静态初始化→执行main”的固定启动流程。
-
位运算高效源于硬件原生支持和JVM深度优化,而非直接操作JVM底层内存;它作用于整数类型的二进制表示,被JIT编译为单条CPU指令,避免对象分配、边界检查与除法开销。
-
Java不手动释放内存是因为依赖GC自动管理堆和元空间内存,避免循环引用、野指针等问题;GC不处理栈、直接内存等区域,System.gc()仅是建议且通常被忽略。
-
TextBlock默认压缩换行符为单空格,需显式设xml:space="preserve"或替换换行符;JSON错位多因BOM/零宽字符,应提前过滤;高亮需拼Run或换AvalonEdit;大SQL卡顿源于TwoWay绑定,应改OneWay并优化数据源。
-
DTO是专用于层间数据传输的精简无逻辑POJO,本质区别在于其明确职责:仅含必要字段且禁止业务方法;而POJO是泛称,无功能约束。
-
封装通过将数据和行为绑定在类中,提升代码可维护性、复用性和安全性;利用访问控制修饰符保护数据,提供可控的访问方式,在setter中加入校验逻辑,防止非法修改;隐藏实现细节使模块独立,接口不变则调用者无需修改,降低耦合;封装支持继承与组合,促进代码复用,符合面向对象设计原则,有助于构建结构清晰、易于扩展和测试的高质量Java应用。
-
HumongousObjects是大小超过半个G1Region的对象,因无法放入Eden区而直接分配到连续的HumongousRegion,跳过年轻代晋升流程,仅能在MixedGC或FullGC中回收,且会推高堆占用率、提前触发并发标记,间接加剧YoungGC频率。
-
静态变量属于类本身,所有实例共享同一内存空间;声明需在类体中加static关键字,推荐private+publicstaticgetter/setter;与实例变量相比,它在类加载时初始化、存于元空间、无需实例即可访问;多线程下需注意线程安全,避免复合赋值引发数据不一致。
-
应提取方法而非深层嵌套——三层以上if需警觉;优先用卫语句+提前返回,封装校验为boolean方法;避免Boolean包装类空指针与==比较;输入统一用nextLine()+try-catch解析。
-
notifyAll()仅将等待线程移入锁竞争队列,不直接执行;线程需重新竞争锁,且wait必须用while循环检查条件,配合同一volatile或同步保护的条件变量,并在synchronized块中对同一对象调用。
-
用ArrayList(set)构造函数转Set最快最直接,时间复杂度O(n),避免手动遍历、Stream或Arrays.asList等低效方式,注意null和代理集合等边界问题。
-
NIO与BIO的核心区别在于:BIO是阻塞式、面向流、一个连接一线程,适用于低并发场景;NIO是非阻塞、面向缓冲区、通过Selector实现单线程管理多连接,适合高并发高性能需求,现代Java后端多采用NIO及Netty等框架。