-
Java开发中建议使用英文路径,核心原因在于避免编码、兼容性和工具链支持问题,包括跨系统编码不一致导致的路径解析失败、JVM及标准库对非ASCII路径支持有限、CI/CD环境locale配置冲突,以及团队协作中Git路径编码不统一引发的乱码与假阳性变更。
-
Java垃圾回收本质是自动管理堆内存,通过可达性分析(以GCRoots为起点)判定对象存活,按分代理论将堆分为新生代(Eden+S0/S1)和老年代,分别采用复制、标记-清除/整理算法回收;MinorGC在Eden满时触发,FullGC在老年代不足等情况下触发。
-
首先确认Java安装并获取路径,然后根据Shell类型选择配置文件,接着设置JAVA_HOME和PATH变量,最后重启终端验证;具体步骤为:1.用java-version和/usr/libexec/java_home确认安装与路径;2.通过echo$SHELL确定使用zsh或bash;3.在~/.zprofile(zsh)中添加exportJAVA_HOME=$(/usr/libexec/java_home)和exportPATH=$JAVA_HOME/bin:$PATH;4.执行source~/.zpr
-
spring-boot-starter-amqp不能替代rabbitmq-client,因其仅为AMQP抽象封装,不包含底层通信实现;必须显式引入兼容版本的rabbitmq-client,并排除starter的默认传递依赖,否则易引发类冲突或连接失败。
-
应先诊断内存问题根源而非盲目调大-Xmx:用jstat查老年代增长、jmap分析对象分布,确认是否泄漏或突发加载;自动堆转储优于手动;G1非万能,需结合GC日志调优;GC日志须独立配置并轮转。
-
构造方法的核心作用是为新创建的对象设置初始状态,确保对象在使用前具备合法、可用的数据和行为基础;它不负责内存分配,而是对JVM已分配的内存进行初始化,包括赋初值、校验参数、预加载资源等,并支持重载以适配不同初始化需求。
-
SOLID原则是达成高内聚、低耦合的手段,核心在于按变化原因划分职责(SRP)、依赖抽象而非实现(DIP、OCP、LSP)、按角色提供精简接口(ISP),并作为重构指南而非编码教条。
-
扫雷核心用二维数组表示格子,元素存未翻开(0)、是雷(-1)或周围雷数(1~8);初始化全0后随机布雷并去重;首次点击才生成数字;点击0格时用BFS递归展开相邻0区域,配合八邻域偏移和边界检查。
-
JDK动态代理通过接口+反射+InvocationHandler统一实现权限校验与事务管理,要求目标类必须实现接口;invoke方法中按序执行权限检查、事务开启、业务调用、提交/回滚;支持注解驱动的条件增强。
-
VerifyError是JVM在类加载连接阶段强制校验字节码失败时抛出的致命错误,发生在ClassLoader.defineClass()阶段,因类型不匹配、栈不平衡等违反JVM规范的问题导致,属不可恢复的Error而非Exception。
-
首先确认JDK安装后通过命令行输入java-version和javac-version均能显示版本号,说明JDK运行环境与编译器已就位;接着检查JAVA_HOME、PATH和CLASSPATH环境变量配置是否正确;最后编写HelloWorld.java程序并成功编译运行输出预期结果,即可验证JDK安装配置完整无误。
-
Java处理嵌套集合需明确每层泛型类型、用Iterator或批量操作避免ConcurrentModificationException、借助Stream扁平化过滤、注意引用语义下修改内层才生效。
-
浅拷贝复制对象时仅复制基本类型值和引用地址,原对象与副本共享引用对象,修改会影响彼此;深拷贝递归复制所有层级,完全独立。实现上,浅拷贝可通过实现Cloneable接口重写clone()方法,深拷贝需手动克隆引用对象或使用序列化、第三方库。选择依据是对象结构复杂度及是否需完全隔离,深拷贝性能开销更大。
-
组合比继承更灵活,因其不受继承层级和final限制,适用于非“is-a”关系、需运行时替换依赖、父类设计不支持继承或需mock测试等场景;推荐privatefinal字段+构造器注入。
-
SpringBoot3要求JDK17或更高版本,最低不支持JDK16及以下;JDK17是基线版本,JDK21受支持且SpringBoot3.2+优化虚拟线程,非LTS版本(18/19/20)不建议生产使用。