-
Arrays.binarySearch返回负值时插入点计算为-(result+1),因需区分查找成功(非负索引)与失败(负值编码),并唯一确定插入位置;插入点即首个≥目标元素的索引,若全小于目标则为数组长度。468 收藏 -
重写equals()时必须同步重写hashCode(),且两者依据的字段严格一致;否则HashMap、HashSet等集合行为异常。推荐用Objects.hash()生成hashCode,避免手工计算。468 收藏 -
ArrayList默认容量为0(JDK12+)或10(早期),size()始终为0直到add();add()末尾追加高效,set()需索引<size(),remove()移除元素导致O(n)移动;遍历时修改会抛ConcurrentModificationException。468 收藏 -
答案:Map.merge()用于合并键值,若键不存在或值为null则插入新值,若键存在则按BiFunction函数更新值。467 收藏 -
Java异常未捕获时自动沿调用栈向上抛出:checked异常需throws声明,unchecked异常可直接抛;应保留原始堆栈信息,避免丢失cause;捕获与否取决于当前层能否真正处理异常而非仅记录日志。467 收藏 -
是的,Java中abstract方法只能定义在abstractclass或interface中;前者需类声明为abstract,后者方法默认publicabstract且不可有构造器或实例字段。467 收藏 -
本文详解Java服务端如何正确向Kotlin客户端发送响应消息,重点解决因换行符缺失导致BufferedReader.readLine()阻塞或读取失败的问题,并提供完整、健壮的双向通信实现方案。466 收藏 -
Java变量必须先声明类型再初始化才能使用,声明锁定变量身份并建立编译期约束,初始化满足确定性要求,使用时全程受静态类型控制,确保类型安全。466 收藏 -
Java8起接口支持静态方法,用于提供不依赖实现类的工具功能,只能通过接口名调用,不可继承或重写,适用于工厂逻辑、通用校验转换等场景,与默认方法相比无this上下文且不可被重写。466 收藏 -
Java中常量用staticfinal定义,须在声明或静态块中初始化,编译期常量(如字面量)可内联优化;enum更安全,适用于互斥、需扩展行为的场景,具类型检查与单例保障;常量接口已淘汰。466 收藏 -
volatile失效并非语法失效,而是因误用(如循环缓存变量、误信字段可见性)或JIT将未观测的volatile读移出循环所致;排查需验证代码语义、JIT行为及运行时环境。466 收藏 -
macOS10.15+系统不再预装java命令,需用brewinstallopenjdk@17安装并手动配置PATH(如exportPATH="/opt/homebrew/opt/openjdk@17/bin:$PATH"),再通过.zshrc或.zprofile生效,IDE需单独配置java.home路径。465 收藏 -
ArrayList扩容的1.5倍通过位运算oldCapacity+(oldCapacity>>1)实现,非硬编码;首次扩容默认为10,后续才用该公式;位运算高效、无精度问题;真正开销在System.arraycopy复制数据。465 收藏 -
不能在遍历中直接调用集合的remove()方法,因为会触发ConcurrentModificationException;必须使用Iterator.remove()或removeIf(),二者均通过同步modCount机制保证安全。465 收藏 -
Map.computeIfAbsent可简化条件赋值,避免null检查,支持惰性求值以提升性能,适用于初始化、嵌套结构构建与缓存场景,需注意无副作用和线程安全问题。464 收藏