-
Java中运行时异常属非检查型异常,编译器不强制处理,常见如NullPointerException等;应优先预防、按类型分层捕获、记录日志或包装重抛,Web应用推荐@ControllerAdvice全局处理,未捕获异常需设Thread.setDefaultUncaughtExceptionHandler兜底。
-
JDK9+中String的value字段改为byte[]+coder以节省内存,Latin-1编码占1字节,UTF16占2字节;反射修改失效、substring不再共享数组、intern()控制常量池引用,不可变性源于封装而非仅final修饰。
-
instanceof本质是运行时安全类型探针,只判断对象是否可能属于某类而不做转换;语法为objinstanceofType,左侧须为引用类型,右侧须为已编译类或接口名,null恒返回false,无继承关系时编译报错。
-
使用AtomicLong可解决高并发下计数器线程安全问题,它通过CAS机制保证原子性,示例中100个线程各递增1000次,最终结果正确为100000。
-
checkMemberAccess拖慢反射调用,因每次setAccessible(true)都触发栈遍历与权限判断;应立即且仅一次设置、缓存已设accessible的反射对象,或改用MethodHandles.Lookup规避。
-
在SpringBoot启动早期阶段,需从外部系统(如密钥管理服务)获取敏感配置(如数据库密码),并确保其在第三方Bean初始化前生效;System.setProperty()无效,应使用EnvironmentPostProcessor在环境准备阶段注入属性。
-
Java中四类引用本质是GC回收时机控制机制:强引用绝不回收,软引用内存不足时回收,弱引用下次GC必回收,虚引用仅用于跟踪回收完成。
-
Pattern和Matcher提供Java中强大的正则处理功能,支持匹配、查找、替换等操作。首先通过Pattern.compile()编译正则,再用matcher()创建Matcher实例,调用find()、matches()或lookingAt()进行匹配。find()用于查找子串,matches()要求全匹配,lookingAt()仅匹配开头。使用括号()可定义分组,group(1)、group(2)等获取捕获内容,适用于提取日期、校验邮箱等场景。实际应用包括敏感词替换、精确字符串分割等,相比Stri
-
Java构造方法必须与类名完全一致(大小写敏感),无返回类型,可重载;new对象时按固定顺序初始化;无显式构造方法时编译器自动添加无参构造,但一旦定义任一构造方法则默认无参构造消失;this()和super()必须位于构造方法首行且互斥。
-
MalformedURLException是受检异常,使用URL构造器时需用try-catch处理格式错误。例如协议拼写错误、缺少协议或含未编码非法字符均会触发该异常,应捕获并提示错误、记录日志或设默认值。建议提前校验URL格式或封装工具方法统一处理,避免程序中断。
-
不能直接减少核心线程数——corePoolSize是只读属性,需通过allowCoreThreadTimeOut(true)+keepAliveTime触发空闲核心线程超时退出;setCorePoolSize()仅影响后续任务分配,不终止已有线程。
-
在FreeMarker模板中,Double类型本身不保存小数位信息,需通过格式化指令(如?string('0.00'))显式指定两位小数输出,确保100.0或100.00均渲染为100.00。
-
Java异常处理核心是try-catch-finally及try-with-resources:try块放可能出错代码,catch按子类到父类顺序捕获并处理,finally确保资源释放;推荐用try-with-resources自动关闭AutoCloseable资源;运行时异常应修复而非捕获,检查型异常须处理或throws声明。
-
Path和Files从设计上解决File类路径、元数据、I/O混杂导致的跨平台错误、静默失败等问题:Path专注可预测路径操作,Files提供语义明确、异常清晰的I/O方法。
-
直接删除config目录比点击「RestoreDefaults」更彻底,因其清除编译器配置、Maven/Gradle路径、SDK绑定等关键设置,而按钮仅重置部分UI偏好。