-
public全开放;protected同包+不同包子类可访问但外部不可点调;default仅同包可见且不继承;private仅本类可见。模块化后default受模块边界限制。
-
MemoryLayout默认不按C对齐,因其是声明式描述且不隐含ABI规则;C结构体对齐由编译器依平台和默认对齐数动态计算,而MemoryLayout.structLayout()若未显式调用.withByteAlignment(n)则仅按字段自然大小对齐,忽略结构体总大小需为最大对齐数整数倍的规则,导致字段错位、越界或崩溃。
-
InvocationTargetException是Java反射调用中封装实际异常的包装类,其真实异常可通过getTargetException()获取。当方法抛出异常时,Java会将其封装在InvocationTargetException中,需通过e.getTargetException()提取原始异常并处理,例如判断类型或打印堆栈信息。若存在嵌套反射调用导致多层包装,可编写工具方法unwrap()递归提取最内层异常。处理建议包括始终捕获InvocationTargetException、避免忽略该异
-
ArrayBlockingQueue是线程安全的有界阻塞队列,基于数组实现,使用ReentrantLock保证同步,创建时需指定容量且不可变,支持公平与非公平策略;提供add、offer、put等入队方法,其中put在队列满时阻塞,适合生产者;提供poll、take、peek等出队方法,其中take在队列空时阻塞,适合消费者;常用于生产者-消费者模型,如任务调度与线程池,需注意合理设置容量与处理中断异常。
-
多态通过动态绑定实现,JVM在运行时根据对象实际类型调用对应方法,利用虚方法表(vtable)查找目标方法。例如,Animala=newDog()调用a.makeSound()时执行Dog类的实现,输出"Woof"。每个类加载时生成vtable,记录可重写方法的地址,调用时先获取对象实际类,再查vtable定位方法执行。尽管存在性能开销,现代JVM已优化此过程。可通过减少继承深度、使用final修饰、优先抽象类而非接口、依赖JIT内联来提升性能。在方法逻辑不随类型变化、性能敏感场景或可用枚举简化设计时,应
-
EntrySet遍历略快于KeySet,因前者复用Node实例而后者每次取node.key;若需value,必须用entrySet(),避免keySet()+get()导致O(n×桶长)性能退化。
-
System.arraycopy()高效复制数组,需预先创建目标数组;2.Arrays.copyOf()简化复制并支持扩容缩容;3.clone()实现基本类型深拷贝、对象数组浅拷贝;4.Arrays.copyOfRange()复制数组片段。根据性能、完整性及范围需求选择合适方法。
-
三元嵌套适用于3–5种状态的简易流转,应左深优先、逐层判断并设兜底值;超4种状态推荐对象映射或switch;需注意类型安全与渲染异常风险。
-
字符串转数字前必须先校验合法性,避免直接解析抛异常;推荐用正则粗筛或ApacheCommonsNumberUtils等成熟工具,并注意各语言特性差异。