-
本文详解Java类路径(CLASSPATH)机制,说明为何javaClassName突然失效,并提供安全、可复用的解决方案——通过临时或永久配置CLASSPATH=.,使JVM默认从当前目录加载类,无需每次手动指定-cp.。
-
Java异常处理需按类型分层捕获、从具体到宽泛;检查型异常须处理或声明,非检查型可不处理;finally应判空关闭资源,优先用try-with-resources;自定义异常应有明确用途且避免过度包装。
-
ArrayStoreException在向数组存入类型不兼容的对象时抛出,如将Integer存入String数组;常见于多态对象数组操作,因JVM运行时类型检查触发。例如Object[]arr=newString[3];arr[0]="Hello";合法,arr[1]=123;则抛出异常。基本类型数组无此问题。避免方法包括:使用具体数组类型、避免用Object[]接收子类数组、运行时类型检查及优先选用泛型集合。可捕获该异常用于调试或容错,但不应作为常规流程。根本解决是合理设计数据结构,以ArrayList
-
多态使同一代码适配不同子类对象,解决新增子类时无需修改原有逻辑的问题;需用父类或接口引用指向子类实例,重写须保持访问权限和返回类型兼容,优先使用接口,default/static方法不参与多态。
-
增强型switch是表达式,必须产出值,故不能用return而需yield;yield专用于提供分支结果,须显式写出且每分支仅一个;混用break会编译错误;仅Java15+支持,低版本运行会抛VerifyError。
-
Java的Pattern/Matcher在处理含Unicode字符(如℃、Ω)的字符串时,可能因字符编码误解或正则表达式书写疏漏导致start()、group()返回异常位置或空值,本质常源于UTF-16代理对误判或正则逻辑缺陷,而非底层编码问题。
-
Set和Map的核心共性是不允许重复key/元素,但语义不同:Set禁重复元素,Map禁重复key(value可重复);均依赖equals()和hashCode()判重(TreeSet/TreeMap例外,用Comparable/Comparator但要求与equals一致);HashSet底层基于HashMap实现,add(e)即map.put(e,PRESENT);默认不保证顺序,需有序用LinkedHashSet/LinkedHashMap或TreeSet/TreeMap;并发集合如Concurre
-
toString方法用于让对象以清晰有意义的字符串形式呈现,避免默认的“类名@哈希值”;必须重写以支持打印、字符串拼接和日志记录;应简洁可读、含关键字段、过滤敏感信息、避免副作用与NPE。
-
finally块用于确保关键代码始终执行,常用于资源释放、状态重置等场景;其典型应用包括关闭文件流、数据库连接,且需注意避免在其中抛出异常或使用return语句,否则可能掩盖异常或改变返回值;现代Java推荐优先使用try-with-resources替代手动资源管理,以提升代码安全性和可读性。
-
<p>TreeMap默认按键的自然顺序排序,可通过构造函数传入Comparator自定义排序规则。例如字符串可按长度排序:TreeMap<String,Integer>map=newTreeMap<>((s1,s2)->s1.length()-s2.length());对自定义对象如Person可按年龄排序:TreeMap<Person,String>map=newTreeMap<>((p1,p2)->Integer.compare(
-
字符串常量池的主要作用是优化字符串存储和重用,节省内存并提高性能。JVM通过确保相同字符串字面量在内存中只存在一份拷贝来实现这一目标。当使用字符串字面量时,JVM首先检查常量池是否存在该字符串,存在则返回引用,不存在则创建并加入池中。String的intern()方法可手动将字符串加入常量池并返回其引用。不同JDK版本中,字符串常量池位置有所变化:JDK1.6及之前位于永久代,JDK1.7移至堆中,JDK1.8后堆中依旧保留。字符串拼接方式影响常量池使用,字面量拼接在编译期优化入池,变量拼接需手动调用in
-
本文介绍一种基于正向先行断言的正则表达式方案,用于精准分割SQL片段中仅出现在AS关键字之后的逗号,避免误切嵌套括号内的逗号,确保字段定义语句保持完整。
-
IdentityHashMap使用==比较键,不调用equals和hashCode,基于引用相等性存储对象,适合需精确区分实例的场景,如框架开发或对象追踪。
-
对象引用赋值是复制内存地址而非对象本身,导致多个变量指向同一实例,修改一处会影响其他变量;基本类型赋值为值复制,各自独立;避免共享需通过构造函数、clone()或序列化实现深拷贝。
-
Java反射调用方法的核心是通过Class获取Method对象后调用invoke(),需注意:1.用getMethod()查public方法(含父类),getDeclaredMethod()查本类所有方法(含private);2.参数类型必须精确匹配;3.private方法需setAccessible(true);4.invoke()第一个参数为对象实例(静态方法传null),异常被包装为InvocationTargetException。