-
字段是Java语法层面的成员变量,属性是OOP中通过getter/setter受控访问的数据抽象;字段关注存储结构,属性强调使用语义与封装行为。
-
答案:Java反射需处理ClassNotFoundException、NoSuchMethodException等异常,建议用try-catch捕获具体异常或统一捕获ReflectiveOperationException,同时优化策略如缓存对象、封装逻辑以提升稳定性。
-
Java异常需转化为业务提示,通过分层设计、自定义BusinessException、错误码规范(如USER_LOGIN_FAIL)、统一@ControllerAdvice处理、国际化文案及前端错误码驱动策略实现,确保不暴露技术细节、不丢失业务含义、不增加调用方负担。
-
Java开发中字符串乱码问题的解决关键在于明确各环节编码方式并正确处理。1.Java中字符串以Unicode存储,但外部数据读取需指定正确编码,如文件读取时用InputStreamReader配合Charset.forName("UTF-8")。2.常见乱码场景包括文件读写、网络请求和数据库交互,分别通过指定文件编码、解析Content-Type头和配置JDBC连接参数来解决。3.编码转换应先用原始编码解码再以目标编码重新构造字符串,避免依赖默认编码和多次转换。4.最佳实践包括统一使用UTF-8、显式指定
-
设计Java继承结构应基于“is-a”关系,合理使用抽象类与接口,优先组合而非继承,遵循里氏替换原则,控制继承深度不超过3层,结合开闭原则和重构优化抽象层次。
-
Java配置中心模块的核心目标是实现应用不重启下的动态配置感知与加载,关键在于变更通知机制与安全替换策略,需结合监听推送、不可变对象+原子引用、异常降级及Spring生态适配等手段保障稳定性。
-
Java中整数乘法运算在编译期和运行期均按操作数类型执行,若两个int相乘,即使结果赋值给long变量,溢出仍发生在int范围内,导致错误结果;正确做法是提前将至少一个操作数提升为long。
-
单例模式只能有一个实例的关键在于私有化构造方法并由类内部管理唯一实例的创建与返回;常用实现有饿汉式(类加载时初始化,线程安全但可能浪费资源)和懒汉式(延迟初始化,需synchronized或DCL+volatile防重排);静态内部类方式因JVM类加载机制天然线程安全且延迟加载,更推荐;多例模式通过key映射有限实例池,用ConcurrentHashMap保证线程安全;Spring的@Scope("singleton")是容器级单例,与编码级单例模式无必然关联,二者控制权不同。
-
不一定。多线程是否提速取决于任务可并行性、CPU密集型(宜匹配核心数)或I/O密集型(受益于并发)、并发开销(锁竞争、上下文切换)及科学基准测试,盲目使用反而更慢。
-
使用同步集合需手动加锁遍历,推荐并发集合如CopyOnWriteArrayList避免异常,迭代删除用Iterator.remove(),或用Stream生成新集合以确保线程安全。
-
程序计数器是JVM中线程私有、无OutOfMemoryError的区域,用于记录当前线程执行的字节码指令地址,支持多线程独立运行,调试时辅助定位执行位置。
-
Vector是线程安全的遗留类,所有public方法加synchronized;ArrayList非线程安全,需手动同步;Vector扩容默认×2且支持自定义增量,ArrayList扩容×1.5;单线程下ArrayList性能更优。
-
CyclicBarrier是可重复使用的线程同步工具,用于让多个线程互相等待至公共屏障点再继续执行;创建时指定线程数量,所有线程调用await()后触发释放,支持屏障动作、超时机制与异常处理,适用于多线程协作计算、并行任务汇总等场景。
-
单线程用StringBuilder,多线程用StringBuffer——必须根据线程环境选择:前者无锁高效,后者同步安全;误用会导致数据错乱或性能浪费。
-
守护线程是为其他线程服务的后台线程,如垃圾回收、监控等,其生命周期依赖于用户线程;1.通过setDaemon(true)设置,需在线程启动前调用;2.JVM在所有用户线程结束后即终止,无论守护线程是否仍在运行;3.适用于可中断的辅助任务,如日志记录、缓存清理,但不应处理关键业务或资源释放;4.典型例子包括JVM的GC线程和心跳检测线程;5.守护线程随主线程生灭,用以提升效率,但需确保任务非核心且可被强制终止。