python函数调用为什么还会有之前调用的残留
这个是代码,在调用时r没传值def get_str(s, ver, r = list()):
for i in range(len(ver)):
for j in range(len(ver)):
if ver == s:
r += [(j, i)]
return random.choice(r)
然后调试发现在第二次调用这个函数时列表r还有之前的变量
如图
怪不得返回老是异常
改到函数内声明r正常
还有,这tm是什么机制,为什么不清理一下,不是有gc吗,为什么还会这样啊啊啊{:301_981:} https://blog.csdn.net/u012409883/article/details/71440711 羊毛丶 发表于 2021-8-12 15:36
https://blog.csdn.net/u012409883/article/details/71440711
涨知识了,还真没遇到这种问题 r别当函数的参数,等你需要调用函数的时候,设置r为全局变量。 首先,你要理解python的可变变量和不可变变量是什么。显然 r = list() 很明显 r是一个可变变量,当可变变量作为参数时,传递的是地址,而不是值,所以你第二次运行这个函数的时候,其实使用的仍是第一次地址,这就是为什么第二次会有第一次的值。 import random
import ctypes
def get_str(s, ver, r = list()):
addr = id(r)
for i in range(len(ver)):
for j in range(len(ver)):
if ver == s:
r += [(j, i)]
return random.choice(r), addr # 把r的地址返回
_, addr = get_str("1", '123')
get_value = ctypes.cast(addr, ctypes.py_object).value # 看看能不能打印出地址里面的值
print(get_value)
_, addr = get_str("1", '123')
发现成功打印,就可以说明一个问题,虽然你给了参数r默认值,但是这个默认值是在函数调用前生成了,属于全局变量
页:
[1]