学习必须往深处挖,挖的越深,基础越扎实!
阶段1、深入多线程
阶段2、深入多线程设计模式
阶段3、深入juc源码解析
阶段4、深入jdk其余源码解析
阶段5、深入jvm源码解析
码哥源码部分
码哥讲源码-原理源码篇【2024年最新大厂关于线程池使用的场景题】
码哥讲源码【炸雷啦!炸雷啦!黄光头他终于跑路啦!】
码哥讲源码-【jvm课程前置知识及c/c++调试环境搭建】
码哥讲源码-原理源码篇【揭秘join方法的唤醒本质上决定于jvm的底层析构函数】
码哥源码-原理源码篇【Doug Lea为什么要将成员变量赋值给局部变量后再操作?】
码哥讲源码【你水不是你的错,但是你胡说八道就是你不对了!】
码哥讲源码【谁再说Spring不支持多线程事务,你给我抽他!】
终结B站没人能讲清楚红黑树的历史,不服等你来踢馆!
打脸系列【020-3小时讲解MESI协议和volatile之间的关系,那些将x86下的验证结果当作最终结果的水货们请闭嘴】
原型模式
定义
类图

实现
1. 浅拷贝
    @Data
    public class SearchWords implements Cloneable{
        String keyWorld;
        long updateTimeStamp;
        long lastUpdateTime;
        ReferenceClass referenceClass;
    
        public SearchWords(String keyWorld, long lastUpdateTime) {
            this.keyWorld = keyWorld;
            this.lastUpdateTime = lastUpdateTime;
        }
    
        @Override
        protected SearchWords clone() throws CloneNotSupportedException {
            SearchWords content = null;
            try {
                content = (SearchWords)super.clone();
            } catch (Exception e) {
                e.printStackTrace();
            }
            return content;
        }
    
        @Override
        public String toString() {
            return "SearchContent{" +
                    "keyWorld='" + keyWorld + '\'' +
                    ", updateTimeStamp=" + updateTimeStamp +
                    '}';
        }
    }
2. 深拷贝
    public Object deepCopy(Object object) throws Exception{
        ByteArrayOutputStream bo = new ByteArrayOutputStream();
        ObjectOutputStream objectOutputStream = new ObjectOutputStream(bo);
        objectOutputStream.writeObject(object);
    
        ByteArrayInputStream bi = new ByteArrayInputStream(bo.toByteArray());
        ObjectInputStream oi = new ObjectInputStream(bi);
        return oi.readObject();
    }
总结
- 浅拷贝和- 深拷贝的区别在于:- 浅拷贝只会复制的索引,不会复制数据本身。相反,- 深拷贝不仅会- 复制索引,还会- 复制数据本身。浅拷贝得到的对象和原始对象- 共享数据,而深拷贝得到的是一份- 独立的对象。
- 如果要拷贝的对象是不可变对象,浅拷贝共享不可变对象是没问题的,但对于可变对象来说,浅拷贝得到的对象和原始对象会共享部分数据,就有可能出现数据被修改的风险,也就变得复杂多了










