python list类型复制(传值,不传值)

本文通过Warshall算法实例,详细介绍了Python中列表作为参数传递时的地址传递特性,探讨了如何避免对原始数据进行意外修改,并提供了解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

python 函数传递 可变类型的变量时 直接传递传过去的 是地址 假如传递的变量是 L(L是list 类型),在 函数体内部 如果出现直接复制,复制的也是地址。 举一下我碰到的问题


def Warshall(L,n):#进行闭包运算  Warshall算法  参数:要闭包运算的矩阵,矩阵的行列数
    f=L
    for c in range(n):
        i=[]
        for r in range(n):
            if f[r][c]!=0:
                i.append(r)
        for j in i:
            l1=chouqujvzhendehang(f,j,n)
            l2=chouqujvzhendehang(f,c,n)
            s=jvzhenhangluojijia(l1,l2,n)
            f[j]=s
    return f

f=L
这句话,是直接把 L的地址给f 也就是 对f做修改的同时也会修改L。
我是不想修改L的 (不然我干嘛要复制,,,)
然后我就从网上找到了一个解决办法
f=L[:]
这样写 就解决了 至于这个问题的底层原理,还有 为什么 ,作为初学者 我现在也不知道 只是想把我碰到的这个问题记一下,感觉挺重要的。

Python中,所有变量名都是对对象的引用。这意味着当你递一个变量到函数时,实际上递的是对象的引用。然而,根据你递的对象类型和操作,这个行为表现得像是调用或引用调用。 1. **调用**:对于可变类型(如整数、浮点数、字符串、元组等),Python的行为类似于调用。当你将这些类型的对象递给函数时,如果在函数内部尝试改变这个对象的Python会创建一个新的对象而是修改原来的对象。由于变量名是引用,所以外部的变量会受到影响。 ```python def change_value(num): num += 10 a = 5 change_value(a) print(a) # 输出仍然是 5 ``` 2. **引用调用**:对于可变类型(如列表、字典、集合等),Python的行为类似于引用调用。当你将这些类型的对象递给函数时,你递的是对象的引用。如果在函数内部对这些对象进行修改,那么原始对象也会被修改,因为实际上递的是对同一个对象的引用。 ```python def change_list(lst): lst.append(10) my_list = [1, 2, 3] change_list(my_list) print(my_list) # 输出 [1, 2, 3, 10] ``` 要控制列表在函数内部是否被修改,你可以使用切片来创建列表的一个浅拷贝,这样在函数内对列表的修改就会影响到原列表。 ```python def change_list(lst): new_lst = lst[:] # 创建列表的一个浅拷贝 new_lst.append(10) my_list = [1, 2, 3] change_list(my_list) print(my_list) # 输出 [1, 2, 3] ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值