-
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等框架。
-
shutdown()后线程池不接受新任务。它将状态设为SHUTDOWN,后续submit()或execute()立即抛出RejectedExecutionException,且不中断正在运行的线程。
-
使用Comparator.comparing()可实现List按属性排序,如按age升序:people.sort(Comparator.comparing(Person::getAge));支持多属性排序thenComparing()、降序reversed(),或通过Stream生成新列表避免修改原数据。
-
应根据场景选择List实现:ArrayList适合随机访问和尾部操作;LinkedList适合头尾增删;CopyOnWriteArrayList适合读多写少的并发场景;Vector已不推荐,synchronizedList需手动同步复合操作。
-
synchronized同步代码块应精准缩小锁范围:只对共享资源加锁,锁对象须共享唯一、稳定不变;推荐privatefinalObjectlock;临界区仅含必要语句;避免锁嵌套与外部调用;按业务选细粒度锁或原子操作。
-
Java中检查Map中某个值是否存在应使用containsValue()方法,它遍历所有value调用equals()比较,时间复杂度O(n),支持null值,但需确保value类正确重写equals和hashCode。