-
答案是:Java数组长度固定,插入需创建新数组并复制元素,使用System.arraycopy分段复制并在指定位置插入新元素,随后可用Arrays.sort()进行快速排序;频繁插入场景建议使用ArrayList,其支持动态扩容和直接插入,排序可借助Collections.sort()。129 收藏 -
TLAB是JVM为每个线程在Eden区预分配的私有内存块,用于无锁对象分配。它通过本地指针碰撞实现快速分配,避免CAS竞争;用完后尝试重分配或退化为共享区加锁分配;大对象、显式关闭等场景会绕过TLAB。129 收藏 -
JVM栈通过栈帧管理方法调用,每个线程独有,栈帧包含局部变量表、操作数栈、动态链接和返回地址;方法调用时压入栈帧,执行完毕后弹出;递归过深可能导致StackOverflowError,栈空间不足则引发OutOfMemoryError。129 收藏 -
不用——但写代码、编译、调试仍需本地JDK;Docker镜像自带JDK仅解决运行时隔离,IDE和mvn等构建工具依赖本地JDK;省掉的是服务器JDK安装,非开发机。129 收藏 -
Java集合初始化需遵循可变性与容量预估原则:该可变时不用只读,该预估大小时不用默认容量;优先用构造参数设初始容量,只读场景用Collections或Guava不可变集合,避免双括号初始化。129 收藏 -
Java文本统计需优先选对字符串处理方式:用codePoints()而非chars()统计真实字符数,用Unicode标点正则分词替代简单空格切分,Files.readString()比newString()更稳且自动处理BOM,String::lines()需手动检查末尾换行符。129 收藏 -
Java中整数乘法运算在编译期和运行期均按操作数类型执行,若两个int相乘,即使结果赋值给long变量,溢出仍发生在int范围内,导致错误结果;正确做法是提前将至少一个操作数提升为long。128 收藏 -
JRE是运行Java程序的环境,包含JVM和核心类库;JDK是开发工具包,包含JRE及编译、调试等工具;开发者需安装JDK,普通用户可仅安装JRE。128 收藏 -
自定义异常通过继承Exception或RuntimeException,结合业务逻辑抛出具体异常如UserExistsException,并利用@ControllerAdvice统一处理,返回友好提示并记录日志,提升系统可读性、健壮性与用户体验。128 收藏 -
WeakHashMap使用弱引用保存键,当键无外部强引用时可被GC回收,适用于缓存等易导致内存泄漏的场景。其值仍为强引用,需注意避免反向引用造成泄漏。与HashMap类似,但性能略低,因每次访问可能触发无效Entry清理。常用于GUI组件映射、附加元数据、弱监听器等场景,是标准库中开箱即用的弱引用Map实现。128 收藏 -
静态成员优先执行,父类静态→子类静态;2.父类实例初始化→父类构造函数→子类实例初始化→子类构造函数;3.每次创建对象均按此顺序执行,静态内容仅加载时执行一次。128 收藏 -
单例模式通过私有构造函数、静态实例和公共获取方法确保类唯一实例;双重检查锁定利用volatile和两次判空检查实现线程安全的懒加载,既提升性能又防止指令重排序导致的不完整实例问题。127 收藏 -
实现Comparable接口可定义类的自然排序,如Student按年龄升序;使用Comparator接口则支持多种定制排序,如按姓名或年龄降序,并可通过thenComparing实现多字段复合排序,适用于灵活、复杂的排序场景。127 收藏 -
多态必须依赖继承和封装:继承提供父类引用指向子类对象的可能,封装通过访问控制确保方法可被重写与安全调用;二者缺一不可,否则无法实现运行时动态绑定。127 收藏 -
Java通配符?提升泛型灵活性,分无界(?)、上界(?extendsT)和下界(?superT);遵循PECS原则:生产用extends,消费用super,避免同时读写。127 收藏