砍材农夫砍材农夫
  • 微信记账小程序
  • java
  • redis
  • mysql
  • 场景类
  • 框架类
  • vuepress搭建
  • hexo搭建
  • 云图
  • 常用工具

    • git
    • gradle
    • Zadig
    • it-tools
    • 开源推荐
    • curl
  • 大前端

    • nodejs
    • npm
    • webpack
    • 微信
    • 正则
    • uniapp
  • java

    • java基础
    • jdk体系
    • jvm
    • spring
    • spring_cloud
    • spring_boot
    • 分库分表
    • zookeeper
  • python

    • python基础
    • python高级
    • python框架
  • 算法

    • 算法
  • 网关

    • spring_cloud_gateway
    • openresty
  • 高可用

    • 秒杀
    • 分布式
    • 缓存一致
  • MQ

    • MQ
    • rabbitMQ
    • rocketMQ
    • kafka
  • 其它

    • 设计模式
    • 领域驱动(ddd)
  • 关系型数据库

    • mysql5.0
    • mysql8.0
  • 非关系型数据库

    • redis
    • mongoDB
  • 分布式/其他

    • ShardingSphere
    • 区块链
  • 向量数据库

    • M3E
    • OPEN AI
  • Jmeter
  • fiddler
  • wireshark
  • AI入门
  • AI大模型
  • AI插件
  • AI集成框架
  • 相关算法
  • AI训练师
  • 量化交易
  • gitee
  • github
  • infoq
  • osc
  • 砍材工具
  • 关于
  • 相关运营
  • docker
  • k8s
  • devops
  • nginx
  • 元宇宙
  • 区块链
  • 物联网
  • linux
  • webrtc
  • web3.0
  • gitee
  • github
  • infoq
  • osc
  • 砍材工具
  • 关于
  • 中考
  • 投资
  • 保险
  • 思
  • 微信记账小程序
  • java
  • redis
  • mysql
  • 场景类
  • 框架类
  • vuepress搭建
  • hexo搭建
  • 云图
  • 常用工具

    • git
    • gradle
    • Zadig
    • it-tools
    • 开源推荐
    • curl
  • 大前端

    • nodejs
    • npm
    • webpack
    • 微信
    • 正则
    • uniapp
  • java

    • java基础
    • jdk体系
    • jvm
    • spring
    • spring_cloud
    • spring_boot
    • 分库分表
    • zookeeper
  • python

    • python基础
    • python高级
    • python框架
  • 算法

    • 算法
  • 网关

    • spring_cloud_gateway
    • openresty
  • 高可用

    • 秒杀
    • 分布式
    • 缓存一致
  • MQ

    • MQ
    • rabbitMQ
    • rocketMQ
    • kafka
  • 其它

    • 设计模式
    • 领域驱动(ddd)
  • 关系型数据库

    • mysql5.0
    • mysql8.0
  • 非关系型数据库

    • redis
    • mongoDB
  • 分布式/其他

    • ShardingSphere
    • 区块链
  • 向量数据库

    • M3E
    • OPEN AI
  • Jmeter
  • fiddler
  • wireshark
  • AI入门
  • AI大模型
  • AI插件
  • AI集成框架
  • 相关算法
  • AI训练师
  • 量化交易
  • gitee
  • github
  • infoq
  • osc
  • 砍材工具
  • 关于
  • 相关运营
  • docker
  • k8s
  • devops
  • nginx
  • 元宇宙
  • 区块链
  • 物联网
  • linux
  • webrtc
  • web3.0
  • gitee
  • github
  • infoq
  • osc
  • 砍材工具
  • 关于
  • 中考
  • 投资
  • 保险
  • 思
  • 基础面试题

    • 基础面试
    • 双亲委派
    • 关于锁
    • 浅拷贝和深拷贝
    • final-finally-finalize
    • 强应用-弱引用-虚引用-软引用
    • Stream流
    • ArrayList&LinkedList&Vector区别
  • 线程并发

    • ThreadLocal
    • 线程
    • 线程安全
    • 线程实现方式
    • 线程相关属性
    • Thread和Object相关方法
    • 线程异常
    • 线程池
  • 高并发(JUC|AQS)

    • concurrency
    • AbstractQueuedSynchronizer
    • CountDownLatch
    • Semaphore
    • CyclicBarrier
    • ReentrantLock
    • Future/FutureTask
    • Fork/Join
    • BlockingQueue
    • ArrayBlockingQueue
    • DelayQueue
    • PriorityBlockingQueue
  • 集合相关

    • 集合相关
    • HashMap和ConcurrentHashMap
  • jvm

    • jvm概览
    • 垃圾标记算法
    • 垃圾回收算法
    • jvm监控相关工具
    • jvm内存调优
  • 锁

    • 死锁
    • volatile
    • synchronized
  • 浅拷贝VS深拷贝
  • 浅拷贝
    • demo
  • 深拷贝
    • 结果
  • 浅拷贝和深拷贝的场景
  • 优化拷贝
    • 问题
    • 其他方式

浅拷贝VS深拷贝

只复制指向某个对象的指针,不复制对象本身,新旧对象共享一个块内存

复制并创建一个一模一样的对象,不共享内存,修改新对象,旧对象保持不变

浅拷贝

demo

package com.jysemel.java.basic;

public class Demo {

    private String name;
    private int age;


    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }
}

package com.jysemel.java.basic;


public class Main {
    public static void main(String[] args) {
        Demo demo = new Demo();
        demo.setName("jysemel");
        demo.setAge(18);

        System.out.println(demo.getName());

        Demo demo1 = demo;
        demo1.setName("jysemel1");

        System.out.println(demo.getName());
        System.out.println(demo1.getName());
    }
}

深拷贝

实现 Cloneable 接口,并重写 clone 方法

package com.jysemel.java.basic;

import lombok.SneakyThrows;

import java.util.List;

public class Demo1 implements Cloneable{

    private String name;
    private int age;

    private List<String> list;


    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    public List<String> getList() {
        return list;
    }

    public void setList(List<String> list) {
        this.list = list;
    }

    @SneakyThrows
    @Override
    public Demo1 clone() {
        return (Demo1) super.clone();
    }

    @Override
    public String toString() {
        return "Demo1{" +
                "name='" + name + '\'' +
                ", age=" + age +
                ", list=" + list +
                '}';
    }
}

package com.jysemel.java.basic;


import java.util.ArrayList;
import java.util.List;

public class Main1 {
    public static void main(String[] args) {
        List<String> list = new ArrayList<>();
        Demo1 demo = new Demo1();
        demo.setName("jysemel");
        demo.setAge(18);
        demo.setList(list);
        demo.getList().add("2");



        System.out.println(demo.getName());

        Demo1 demo1 = demo.clone();
        demo1.setAge(19);
        demo1.setName("jysemel1");
        demo.getList().add("4");

        System.out.println(demo);
        System.out.println(demo1);
    }
}

结果

Demo1{name='jysemel', age=18, list=[2, 4]}
Demo1{name='jysemel1', age=19, list=[2, 4]}

String 对象一旦创建,内容不会变,修改会创建新对象,不会改变原来的对象

list 引用类型,没有进行深拷贝,修改会改变原来的对象

浅拷贝和深拷贝的场景

1、避免线程间共享可变状态导致线程安全问题,可传递该对象的深拷贝副本
2、DTO(数据传输对象)转换
3、缓存快照

优化拷贝

问题

1、对象嵌套层次越深,深拷贝的开销就越大
2、对于大量对象的复制操作,深拷贝可能导致性能下降

其他方式

其一 序列化 demo

package com.jysemel.java.basic.demo3;

import java.io.*;

public class Dept implements Serializable {

    private static final long serialVersionUID = 1L;

    private String name;
    private String address;

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getAddress() {
        return address;
    }

    public void setAddress(String address) {
        this.address = address;
    }

    @Override
    public String toString() {
        return "Dept{" +
                "name='" + name + '\'' +
                ", address='" + address + '\'' +
                '}';
    }

    public Dept(String name, String address) {
        this.name = name;
        this.address = address;
    }

    // 深拷贝方法:利用序列化
    Dept deepCopy() {
        try {
            // 写入字节数组流
            ByteArrayOutputStream baos = new ByteArrayOutputStream();
            ObjectOutputStream oos = new ObjectOutputStream(baos);
            oos.writeObject(this);
            oos.close();

            // 从字节数组流读取
            ByteArrayInputStream bais = new ByteArrayInputStream(baos.toByteArray());
            ObjectInputStream ois = new ObjectInputStream(bais);
            return (Dept) ois.readObject();
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
    }
}
package com.jysemel.java.basic.demo3;

public class SimpleDeepCopyDemo {

    public static void main(String[] args) {

        Dept p1 = new Dept("张三", "333");

        // 深拷贝
        Dept p2 = p1.deepCopy();

        // 打印原始和副本
        System.out.println("原始: " + p1);
        System.out.println("副本: " + p2);

        // 修改副本的基本类型字段
        p2.setName("李四");
        p2.setAddress("李四33");

        // 再次打印,观察原始对象是否被影响
        System.out.println("\n修改副本后:");
        System.out.println("原始: " + p1); // 原始对象不受影响
        System.out.println("副本: " + p2);
    }
}

最近更新: 2026/2/12 16:16
Contributors: kcnf
Prev
关于锁
Next
final-finally-finalize