1. 引用自身
虽然Python是动态解释型语言,但在解释到
class UserInfo:
# ...
next = UserInfo() # <===
这句时,由于类UserInfo还没定义结束,直接开始使用是不行的。但是Python本身由于是动态解释运行的,完全可以利用动态修改内容(甚至新增属性)来解决这个需求。例如
class UserInfo:
# ...
next = None
user = UserInfo()
user.next = UserInfo()
当然,这样就做不到一个类内初始化了,那么可以使用一些魔术方法
class UserInfo:
def __init__(self):
# 要注意执行__new__创建的实例是没经过__init__初始化的,切记
# 这在做很多lazy-loading的时候很管用
self.next = UserInfo.__new__(UserInfo)
2. 参数的引用传递
简单来说
Python中的参数传递都是对参数引用的传递
参数的类型可以分为可变的(mutable)以及不可变的(immutable)
举点例子
list是可变的,如果在函数内直接对其进行修改,而不修改引用,那么将会改变参数内容
def test(n):
n.append(2)
m = [1]
test(m)
print(m) # 这里将会输出 [1, 2]
如果调换参数的引用的话
def test(n)
n = [2] # 这里其实已经将参数的引用调换了
m = [1]
test(m)
print(m) # 所以这里将输出[1]
str是不可变的,也没有对其inplace操作的方法,皆为返回一个新的copy
def test(n)
n = "Hello, Python!"
m = "Hello, World!"
test(m)
print(m) # 这里还是Hello, World!
stackoverflow上个更清楚的回答: