-
Java字符串+拼接在编译期仅对常量字面量直接合并为单个字符串,对局部变量则优化为StringBuilder调用;循环中动态拼接不会优化,需显式使用StringBuilder避免性能问题。
-
使用接口与依赖注入实现松耦合:1.接口定义行为,分离“做什么”与“怎么做”;2.依赖注入传递实现,避免类内直接new对象;3.Spring框架通过@Autowired自动装配,简化配置;4.松耦合提升可维护性、可测试性,支持灵活替换实现,符合开闭原则。
-
ConcurrentHashMap默认loadFactor为0.75是工程权衡最优解,兼顾哈希冲突概率、内存占用与扩容开销;过高(如0.9)加剧碰撞、锁争用与树化开销,过低(如0.5)则浪费内存、增加扩容频次且损害缓存局部性。
-
Java版本与JAVA_HOME配置错误导致编译运行失败:需确保JAVA_HOME指向JDK根目录(非bin)、路径无空格/中文;Maven需≥3.6.3且maven-compiler-plugin≥3.8.0;IDE需独立配置JDK路径;多JDK共存时应统一终端实际调用版本。
-
Future是Java中用于异步任务结果获取与状态管理的占位符,需通过ExecutorService提交Callable任务获得,提供get()、isDone()、cancel()等方法;其局限性包括无链式调用、无回调机制、异常处理被动、多任务协调困难,新项目应优先使用CompletableFuture。
-
匿名内部类是Java中无需命名即可实现接口或继承抽象类的方式,适用于一次性、轻量级场景,如事件监听、线程启动、自定义排序等;其语法为new接口/抽象类(参数){实现体},要求基于已有类型、可访问外部final变量、不可定义静态成员(除staticfinal外)。
-
方法重载发生在同一类中,参数列表不同,用于支持多种调用方式;方法重写发生在子类与父类间,方法名和参数相同,用于实现多态。
-
字符串格式化效率排序为:直接拼接(+)>StringBuilder>MessageFormat>String.format;高频场景用+或StringBuilder,国际化用MessageFormat,调试日志可用String.format,JDK21StringTemplate为未来优选。
-
Java邮件通知服务核心是用JakartaMailAPI配合SMTP协议,需正确配置服务器参数、认证方式及邮件内容,并注意授权码使用、中文编码、附件处理与生产环境的可配置性、重试、日志和安全管控。
-
应继承RuntimeException并定义带errorCode和context的异常基类,errorCode用枚举或常量,保留原始异常链,变量存context而非message,重写toString以输出关键信息。
-
Java泛型在编译期通过静态类型检查阻止类型错误,依赖类型擦除机制在插入/获取处自动插入检查与转换;裸类型放弃约束,导致运行时ClassCastException;泛型不支持基本类型、数组、instanceof及newT(),且反射、@SuppressWarnings和通配符滥用可绕过检查。
-
Gson反序列化时若JSON存在顶层包装字段(如"billingInformation":{...}),而直接映射到BillingInformation.class,会导致所有字段为null;必须定义与JSON结构完全匹配的封装类(如Data),再从中提取目标对象。
-
super用于调用父类成员,1.可在子类中通过super.方法名()调用被重写的父类方法,实现逻辑扩展;2.子类构造器必须首行通过super()调用父类构造器,否则需确保父类有无参构造器;3.实际开发中常先调用super.method()执行基础逻辑,再添加子类特有行为;4.注意super不能在静态上下文中使用,super()必须是构造器第一条语句,且应避免过度依赖继承,优先使用组合。正确使用super能提升代码复用性与可维护性。
-
线程池拒绝策略必须选用CallerRunsPolicy或自定义策略,配合有界队列(如ArrayBlockingQueue)和显式构造的ThreadPoolExecutor;禁用Executors工厂方法;需监控活跃线程数、队列积压量及拒绝次数;多业务应拆分独立线程池实现风险隔离。
-
直接删除config目录比点击「RestoreDefaults」更彻底,因其清除编译器配置、Maven/Gradle路径、SDK绑定等关键设置,而按钮仅重置部分UI偏好。