-
List是可重复的有序队列,支持索引访问和重复元素;Set是自动去重的存在集合,只关心元素是否存在,不保证顺序(除非LinkedHashSet/TreeSet)。
-
1.如何利用反射实现通用对象拷贝?通过获取源对象和目标对象的Class结构遍历目标类的setter方法找到源类中匹配字段名的getter方法使用Method.invoke()进行赋值publicstaticvoidcopyProperties(ObjectdestObjectsrc)throwsException{Class<?>srcClass=src.getClass();Class<?>destClass=dest.getClass();for(MethoddestMetho
-
多态不是语法糖,是运行时通过虚方法表动态绑定:编译看引用类型,运行看实际对象类型;static方法、字段、private/final方法不参与动态绑定。
-
接口设计需贯穿全流程:明确职责、隔离实现、测试验证、工具保障,确保契约落地。
-
Java数组初始化分静态和动态两种:静态初始化在声明时直接赋值,编译器自动推断长度,如int[]arr={1,2,3};动态初始化先用new指定长度创建数组,再赋值,如int[]arr=newint[5]。
-
IllegalArgumentException由方法内部抛出,不该捕获——它标识调用方传入非法参数的逻辑错误;应尽早校验并明确提示非法值与合法范围,优先使用Objects.requireNonNull或GuavaPreconditions简化断言。
-
Java中Queue接口是FIFO抽象,推荐用ArrayDeque实现;其offer/poll/peek方法比add/remove/element更安全;ArrayDeque非线程安全且禁null,PriorityQueue不保证FIFO,多线程应选ConcurrentLinkedQueue。
-
PriorityQueue默认基于小顶堆实现,不保证数组有序,仅维护堆性质;offer/poll时间复杂度为O(logn),peek为O(1);自定义排序需用Comparator或Comparable;不支持元素修改后自动重排序。
-
虚引用用于跟踪对象被垃圾回收的时机,必须与ReferenceQueue配合使用,无法获取对象实例,仅在对象彻底回收后入队通知,是JVM资源生命周期管理的“最后一道哨兵”。
-
封装通过private修饰字段并提供getter/setter方法,保护数据安全、提升可维护性,防止外部直接访问,并支持校验、扩展与副本返回,增强类的健壮性与灵活性。
-
WeakHashMap使用弱引用保存键,当键无外部强引用时可被GC回收,适用于缓存等易导致内存泄漏的场景。其值仍为强引用,需注意避免反向引用造成泄漏。与HashMap类似,但性能略低,因每次访问可能触发无效Entry清理。常用于GUI组件映射、附加元数据、弱监听器等场景,是标准库中开箱即用的弱引用Map实现。
-
本文深入探讨了Hibernate中One-to-One映射的外键约束违规问题,特别是当父实体引用未持久化的子实体时。通过分析经典的ORA-02291错误,文章提供了两种有效的解决方案:手动控制实体持久化顺序和利用JPA的@OneToOne注解配合CascadeType进行级联操作,旨在帮助开发者构建健壮的Hibernate实体关系。
-
子类覆盖父类方法是实现多态的核心,需满足方法名、参数列表一致,返回类型兼容,访问权限不更严格,且不能覆盖private、static、final方法。例如Animal类的makeSound()被Dog类重写,通过Animala=newDog();a.makeSound();调用时,实际执行Dog类的方法,体现“编译看类型,运行看对象”的动态绑定机制。该机制提升代码扩展性与维护性,允许统一处理不同对象,如Shape类的draw()在Circle、Rectangle中各自实现,便于集合操作和后续扩展。
-
JarInputStream用于流式遍历JAR内容,逐个读取JarEntry,不加载全文件到内存;需传入mark-supported输入流,自动解析MANIFEST.MF,通过getNextJarEntry()循环获取条目,目录以/结尾,须校验路径防遍历,推荐用于单次扫描场景。
-
设置Java环境变量需配置JAVA_HOME指向JDK路径,并将%JAVA_HOME%\bin添加到Path,最后通过java-version、javac-version和echo%JAVA_HOME%验证;若应用无法识别,可能是未重启、多版本冲突、应用自身配置覆盖或用户/系统变量混淆;管理多版本推荐使用SDKMAN!、软链接或IDE独立配置以实现灵活切换。