Joh*_*nal 3 python multithreading atomic thread-safety atomicity
x,y = self.mytuple在Python中是一个像atomic 一样的操作吗?
或者可以self.mytuple在赋值期间由另一个线程修改,导致x引用self.mytuple的第一个版本,y引用第二个版本?
我正在使用Python 3.
只有当Python代码不处理项目访问时,它才是线程安全的.
解包由一个字节码处理:
>>> def f():
... a, b = self.mytuple
...
>>> import dis
>>> dis.dis(f)
2 0 LOAD_GLOBAL 0 (self)
3 LOAD_ATTR 1 (mytuple)
6 UNPACK_SEQUENCE 2
9 STORE_FAST 0 (a)
12 STORE_FAST 1 (b)
15 LOAD_CONST 0 (None)
18 RETURN_VALUE
Run Code Online (Sandbox Code Playgroud)
提供的self.mytuple是真正的标准Python tuple,即线程安全.
一旦从mytuple触发器访问项目自定义__getitem__,所有投注都将关闭.