-
BigDecimal构造应避免double参数,须用String或valueOf;四则运算必须调用add、subtract等方法;比较大小唯一可靠方式是compareTo;setScale和divide需按业务选RoundingMode,货币标度通常为2。
-
CodeCache满时JIT编译器被硬性禁用而非停顿:达到-XX:ReservedCodeCacheSize上限后,JVM立即停止所有新方法的JIT编译并输出禁用日志,已编译代码仍执行,新热点全部退至解释执行,性能下降5–10倍。
-
构造方法是对象创建时强制触发的初始化入口,用于确保成员变量具备明确初始状态;它无返回类型、名须与类同、不可被static/final/abstract修饰;写有参构造后编译器不再自动生成无参构造,需手动补全;重载时应规范参数顺序并用this()委托;适合处理不可变或必填字段,而setter适用于后期动态修改。
-
首先定义带返回值的方法需指定返回类型、方法名和参数列表,如publicstaticintadd(inta,intb){returna+b;};调用时可将结果赋值给变量,如intresult=add(5,3);;返回类型应与实际数据匹配,常用有int、double、String、boolean等;注意所有路径必须返回值且类型兼容,避免编译错误。
-
finally中的return会覆盖try/catch的返回值并吞掉异常;正确做法是用局部变量记录结果,清理逻辑放在finally中,最终在方法末尾统一return。
-
直接调用StringBuilder.setLength(0)是最轻量的重置方式,它不释放底层char数组,仅将长度计数器归零,后续append()从索引0覆盖写入,避免重复分配和构造开销。
-
transient关键字用于指定字段不被序列化,如敏感信息、临时数据或线程资源,防止其写入持久化介质;反序列化时这些字段恢复为默认值。例如User类中password和loginCount声明为transient后不会被自动序列化,但可通过重写writeObject和readObject方法实现加密存储与恢复,从而在安全性和灵活性间取得平衡。
-
继承与组合的性能差异可忽略,现代JVM优化使两者运行效率相近。1.继承依赖动态分派,但JVM通过内联缓存和方法内联大幅降低开销;深层继承链和状态膨胀可能间接影响性能。2.组合调用更易预测,JVM同样可优化方法转发,其优势在于职责清晰、支持运行时替换。3.内存方面,继承可能导致冗余字段增加实例大小,组合按需引用更紧凑,但引入对象引用和GC压力。4.设计上,组合优于继承:避免封装破坏、降低耦合、提升可维护性与扩展性,符合“优先使用组合”原则。5.实际性能瓶颈罕见,应优先关注代码结构与可测试性,仅在高频场景通过
-
Java有8种基本数据类型:整数型(byte、short、int、long)、浮点型(float、double)、字符型(char)、布尔型(boolean);其与引用类型的核心区别在于存储内容、内存位置、默认值、是否可为null及参数传递方式。
-
主流语言for循环初始化不支持多类型变量声明,因语法限制要求单一表达式或同类型声明;性能瓶颈在于重复计算、内存访问模式等,而非变量声明方式。
-
封装是将属性和行为包装在类中,通过private隐藏字段并提供getter/setter方法控制访问,结合构造器校验和行为封装,确保对象状态安全,降低耦合,提升代码可维护性。
-
应避免使用SimpleDateFormat.parse()处理时间戳,正确做法是用newDate(long)构造再format();需显式设置时区防止偏移;因其线程不安全,推荐每次new、ThreadLocal封装或升级到Java8的DateTimeFormatter。
-
方法的返回类型和参数列表是方法签名的核心,决定输入输出;2.返回类型可为基本类型、引用类型或void,非void需用return返回对应值;3.参数需明确类型和名称,多个参数用逗号分隔且类型不可省略;4.参数名应具可读性,方法内作为局部变量使用;5.调用时传参类型必须匹配,否则编译错误。
-
Java环境在运行过程中可能受到系统安全策略的限制,导致某些操作被拒绝,比如文件读写、网络连接、反射调用等。排查这类问题需要从Java自身的安全管理器(SecurityManager)和系统层面的策略两方面入手。以下是几个实用的排查技巧。检查是否启用了SecurityManagerJava的安全限制通常由SecurityManager控制。如果应用中显式设置了SecurityManager,或通过启动参数加载了安全策略,就可能触发权限检查。可通过以下方式确认:在代码中添加:System.g
-
CopyOnWriteArraySet写操作慢因每次add/remove需复制整个底层数组(O(n)),适合写少读多场景;迭代器基于快照,遍历时修改无效;与synchronizedSet相比,其读无锁、写独占、迭代免锁。