zoukankan      html  css  js  c++  java
  • 深浅拷贝

    深浅拷贝

    浅拷贝

    l1 = [1,2[1,2]]

    l1 = [1, 2, [1,2]]
    # 分析深浅拷贝
    

    ​ 浅拷贝对于不可变的是的数据类型是指针指向沿用原来的,对可变的数据类型还是沿用原来的对象,所以对外不可变的数据类型不会相互改变这一点和深拷贝也是一样的,而不同的是浅拷贝对于可变的数据类型是沿用而不是重新指向一个新的列表,所以会相互影响相互牵制。一个改变变可变类型也会改变另一个的内部值。

    ​ 内部的值相互可以改变,也就是一方改另一方也随之改变,外部的值为不可变数据类型,指针还是指向原来的值

    # 2.区别深浅拷贝
    # l1[0] = 222
    # print(l1,id(l1))  # [222, 2, ['al', 'js']] 2130503833736
    # print(l3,id(l3))
    # [222, 2, ['al', 'js']]  # [1, 2, ['al', 'js']] 2130503843720
    # [1, 2, ['al', 'js']]
    
    # l3[0] =333
    # l3[2][0] = 'xx'
    # print(l1)
    # print(l3)
    
    # [1, 2, ['xx', 'js']]
    # [1, 2, ['xx', 'js']]
    
    l4 = copy.deepcopy(l1)  # >>>深拷贝id也会变
    
    # 2.
    # l1[0]=222
    # l1[2][1] = 'ss'
    # print(l1)
    # print(l4)
    
    # l4[2][0] = 33
    # print(l1)
    # print(l4)
    # l1[2][1] = 44
    # print(l1)
    # print(l4)
    # [1, 2, [1, 44]]
    # [1, 2, [1, 2]]
    

    img

    深拷贝是对于不可变数据类型是指针指向,而对于可变的数据类型,是重新开一个类型重新指向,值还是沿用原指针指向的值,不同的是可变的数据类型之间不再相互随着改变而改变。
    

      

    img

    千里之行,始于足下。
  • 相关阅读:
    远程接入系统的问题
    FastReport
    通用FASTREPORT打印模块及接口方法
    cxGrid控件过滤筛选后如何获更新筛选后的数据集
    Oracle Data Integrator 12c (12.1.2)新特性
    ODI 12c 安装
    Kafka面试题
    Hadoop面试题
    Spark面试题
    JAVA面试题-数组字符串基础
  • 原文地址:https://www.cnblogs.com/jincoco/p/11598773.html
Copyright © 2011-2022 走看看