-
Java接口异常设计是契约的一部分,需区分检查型与非检查型异常:前者强制处理,适用于可恢复业务异常;后者用于编程错误;应封装底层异常为语义明确的自定义异常,避免滥用,配合文档与规范确保一致性。
-
String.lines()返回空流是因为原始字符串不含换行符(\n、\r\n、\r);它语义化分割且不保留终结符,而split()需手动匹配换行变体并可能产生空串。
-
实体类代表事物本身,承载状态与身份,如User、Order;行为类专注做事,提供算法或协调能力,如PaymentProcessor、DiscountCalculator。区分关键在职责:实体被持有,行为被使用。
-
类和对象是Java中面向对象编程的核心概念。类是模板,定义了属性和方法;对象是类的实例,具有具体的值和行为。类与对象的关系类似于剧本和演员:类是剧本,定义了角色的行为和特征;对象是根据剧本上演的具体演员。
-
绝大多数情况下catch块必须记录日志,但仅限真正处理并终结异常传播路径时;业务异常用warn,系统异常用error并保留完整堆栈;避免重复记录、截断堆栈及异步场景日志丢失。
-
先使用setx命令永久配置Java环境变量。确认JDK安装路径后,用setxJAVA_HOME设置根目录,再用setxPath添加%JAVA_HOME%\bin到系统Path,最后重新打开cmd验证java-version和javac-version输出。
-
Hashtable一放null就抛NullPointerException,因其所有public修改方法均在执行时立即调用Objects.requireNonNull(key/value),将键值非空作为设计契约;containsKey(null)和containsValue(null)则始终返回false。
-
静态方法适用于无状态、纯函数型工具逻辑,如日期格式化;应避免隐含依赖、副作用及测试障碍,优先采用依赖注入与接口设计。
-
ArrayList线程不安全因其方法无同步控制,多线程并发add可能引发扩容竞态,导致ArrayIndexOutOfBoundsException、数据丢失或ConcurrentModificationException。
-
在Java中,LinkedHashMap是HashMap的一个子类,它通过维护一个双向链表来保证元素的插入顺序。这意味着当你遍历LinkedHashMap时,元素的返回顺序与它们被插入的顺序一致。这一点与HashMap不同,HashMap不保证任何顺序。保持插入顺序的基本用法创建一个LinkedHashMap非常简单,和HashMap的使用方式几乎一样:LinkedHashMapmap=newLinkedHashMap();map.put("apple",1
-
JavaJIT通过回边与调用计数器识别热点循环,自动执行展开、向量化和范围检查消除;需避免反射、大循环体、异常等干扰,并用诊断参数验证优化效果。
-
合并List首选addAll(),需目标集合可变;Set合并推荐构造器+addAll();Stream.concat()仅支持两流且不处理null;GuavaIterables.concat()为懒视图,需转实体集合。
-
最直接的方法是调用clear()方法,该方法会移除集合中所有元素,使集合变为空,适用于ArrayList、HashSet、HashMap等实现Collection接口的集合类,调用后原对象仍存在但元素被删除,若需释放内存可将引用置为null,注意多引用时clear()会影响所有指向该集合的对象。
-
Java序列化安全漏洞的根本原因在于其“过度灵活”与“隐式执行”特性。1.反序列化时自动调用readObject()等“魔术方法”,攻击者可构造恶意字节流触发非预期操作;2.利用多个类的“魔术方法”串联形成“GadgetChain”,如ApacheCommonsCollections中的InvokerTransformer,实现远程代码执行;3.开发者对内部系统的隐式信任导致边界模糊,使不可信数据被反序列化后成为后门。常见攻击载荷包括ApacheCommonsCollections、SpringFrame
-
Java中二维数组实为“数组的数组”,支持不规则结构;声明如int[][]arr=newint3或int[][]arr={{1,2},{3,4,5},{6}};遍历时需判空防NullPointerException。