zoukankan      html  css  js  c++  java
  • 7.深浅copy

    list1 = ['egon','lxx',[1,2]]
    #二者分隔不开,list1改list2也跟着改,因为指向的就是同一个内存地址
    list2 = list1 #这不叫拷贝
    list1[0] = 'EGON'
    print(list2)
    

    1.浅copy

    是把原列表第一层的内存地址不加区分完全copy一份给新列表

    #实验1:浅copy拷贝第一层内存地址,第一层内存地址中的不可变类型更改后,浅copy不改,任然指向旧地址,第一层内存中的可变类型更改后,浅copy数据也跟着改变
    list1 = ['egon','lxx',[1,2]]
    list3 = list1.copy()
    print(list3)
    print(id(list1))
    print(id(list3))
    
    print(id(list1[0]),id(list1[1]),id(list1[2]))
    print(id(list3[0]),id(list3[1]),id(list3[2]))
    
    list1[0] = 'EGON'
    list1[1] = 'LXX'
    list1[2] = 123
    #实验2:但对于可变类型,我们可以改变类型中包含的值,但内存地址不变,即原列表的索引任然指向原来的内训地址,于是新列表也跟着一起受影响
    list1[2][0] = 111
    list1[2][1] = 222
    print(list1)
    print(list3)
    

    综合实验1与实验2可以得出,要想copy得到的新列表与原列表的改操作完全独立开,必须有一种可以区分开可变类型与不可变类型的copy机制,这就是深copy

    2.深copy

    import copy
    
    list1 = ['egon','lxx',[1,2]]
    list3 = copy.deepcopy(list1)
    print(id(list1))
    print(id(list3))
    '''
    2517703492224
    2517703491968
    '''
    
    #         不可变       不可变         可变
    print(id(list1[0]),id(list1[1]),id(list1[2]))
    print(id(list3[0]),id(list3[1]),id(list3[2]))
    '''
    2517701051248 2517696265840 2517703494720
    2517701051248 2517696265840 2517703492928
    '''
    
    print(list3)
    print(id(list1[2][0]),id(list1[2][1]))
    print(id(list3[2][0]),id(list3[2][1]))
    '''
    1747675736368 1747675736400
    1747675736368 1747675736400
    '''
    
    list1[0] = 'EGON'
    list1[1] = 'LXX'
    list1[2][0] = 111
    list1[2][1] = 222
    print(list1)
    print(list3)
    '''
    ['EGON', 'LXX', [111, 222]]
    ['egon', 'lxx', [1, 2]]
    '''
    
  • 相关阅读:
    Codeforces 231E
    Practice 15.07.07 计算几何
    Codeforces 552E
    Topcoder SRM 661 (Div.1) 250 MissingLCM
    HDU 4971
    Codeforces Round #306 (Div. 2)
    URAL 1988
    URAL 2032
    ServiceStack.Ormlit 事务
    ServiceStack.Ormlit 使用Insert的时候自增列不会被赋值
  • 原文地址:https://www.cnblogs.com/Psc-mmf/p/13904673.html
Copyright © 2011-2022 走看看