金三银四面试题(十四):Java基础问题(5)

这部分面试题多用于面试的热身运动,对很多找实习和准备毕业找工作的小伙伴至关重要。

避免序列化

可以使用transient 关键字修饰不想进行序列化的变量。

transient 关键字的作用是:阻止实例中那些用此关键字修饰的变量序列化;当对象被反序列化时,被transient 修饰的变量值不会被持久化和恢复。

注意transient 只能修饰变量,不能修饰类和方法。

强弱软虚四种引用

  1. 强引用

    强引用是平常中使用最多的引用,强引用在程序内存不足(OOM)的时候也不会被回收

  2. 软引用

    软引用在程序内存不足时,会被回收,

    // 注意:wrf 这个引用也是强引用,它是指向SoftReference 这个对象的,
    // 这里的软引用指的是指向new String("str")的引用,也就是SoftReference 类中T
    SoftReference<String> wrf = new SoftReference<String>(new String("str"));

创建缓存的时候,创建的对象放进缓存中,当内存不足时,JVM 就会回收早先创建的对象。

  1. 弱引用
    弱引用就是只要JVM 垃圾回收器发现了它,就会将之回收,

    WeakReference<String> wrf = new WeakReference<String>(str);

  2. 虚引用
    虚引用的回收机制跟弱引用差不多,但是它被回收之前,会被放入ReferenceQueue
    中。注意哦,其他引用是被JVM 回收后才被传入中的。由于
    这个机制,所以虚引用大多
    被用于引用销毁前的处理工作。还有就是,虚引用创建的时候,必须带有ReferenceQueue

    PhantomReference<String> prf = new PhantomReference<String>(new String("str"),new ReferenceQueue<>());

深拷贝和浅拷贝

浅拷贝(shallowCopy)只是增加了一个指针指向已存在的内存地址,

深拷贝(deepCopy)是增加了一个指针并且申请了一个新的内存,使这个增加的指针指向这个

新的内存,

使用深拷贝的情况下,释放内存的时候不会因为出现浅拷贝时释放同一个内存的错误。

最好是结合克隆以及原型模式联系在一起哈,记得复习的时候,把这几个联系起来的。

sublist方法

这个之前面腾讯被问过。

List 接口提供了一个名为 subList(int fromIndex, int toIndex) 的方法,用于获取原始列表中从 fromIndex(包括)到 toIndex(不包括)之间的子列表。这个子列表是原始列表的一个视图,对子列表的修改会影响原始列表,反之亦然。

这个方法的用法如下:

java 复制代码
import java.util.ArrayList;
import java.util.List;

public class Main {
    public static void main(String[] args) {
        ArrayList<Integer> originalList = new ArrayList<>();
        for (int i = 0; i < 10; i++) {
            originalList.add(i);
        }

        // 获取子列表(包括第3个元素,不包括第7个元素)
        List<Integer> subList = originalList.subList(2, 7);

        System.out.println("Original List: " + originalList);
        System.out.println("Sub List: " + subList);

        // 修改子列表
        subList.set(0, 100);
        System.out.println("Original List after modifying Sub List: " + originalList);
        System.out.println("Sub List after modifying: " + subList);

        // 修改原始列表
        originalList.set(3, 200);
        System.out.println("Original List after modifying: " + originalList);
        System.out.println("Sub List after modifying Original List: " + subList);
    }
}

我们创建了一个包含0到9的整数的 ArrayList,然后使用 subList() 方法获取了一个子列表,从索引2(包括)到索引7(不包括)。修改子列表或原始列表都会相互影响。

往期文章

金三银四面试题(十三):Java基础问题(4)2024-04-03

金三银四面试题(十二):Java基础问题(3)2024-04-02

金三银四面试题(十一):Java基础问题(2)2024-04-01

金三银四面试题(十):Java基础问题(1)2024-03-31

金三银四面试题(九):JVM常见面试题(3)2024-03-30

金三银四面试题(八):JVM常见面试题(2)2024-03-30

金三银四面试题(七):JVM常见面试题(1)2024-03-28

金三银四面试题(六):对象大小知多少2024-03-27

金三银四面试题(五):JVM之TLAB2024-03-26

金三银四面试题(四):Full GC 和 Minor GC2024-03-25

相关推荐
over6972 小时前
从 LLM 到全栈 Agent:MCP 协议 × RAG 技术如何重构 AI 的“做事能力”
面试·llm·mcp
心之语歌2 小时前
基于注解+拦截器的API动态路由实现方案
java·后端
SuperEugene3 小时前
Vue状态管理扫盲篇:如何设计一个合理的全局状态树 | 用户、权限、字典、布局配置
前端·vue.js·面试
华仔啊3 小时前
Stream 代码越写越难看?JDFrame 让 Java 逻辑回归优雅
java·后端
ray_liang3 小时前
用六边形架构与整洁架构对比是伪命题?
java·架构
Ray Liang5 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
Sailing5 小时前
🚀 别再乱写 16px 了!CSS 单位体系已经进入“计算时代”,真正的响应式布局
前端·css·面试
Java水解5 小时前
Java 中间件:Dubbo 服务降级(Mock 机制)
java·后端
SuperEugene7 小时前
Vue状态管理扫盲篇:Vuex 到 Pinia | 为什么大家都在迁移?核心用法对比
前端·vue.js·面试
Hilaku8 小时前
我会如何考核一个在简历里大谈 AI 提效的高级前端?
前端·javascript·面试