lem*_*ant 137 python multithreading list python-multithreading python-3.x
我注意到经常建议使用具有多个线程的队列,而不是列表和.pop().这是因为列表不是线程安全的,还是出于其他原因?
Tho*_*ers 163
列表本身是线程安全的.在CPython中,GIL可以防止对它们进行并发访问,而其他实现则会为其列表实现使用细粒度锁或同步数据类型.但是,虽然列表本身不会因同时访问的尝试而损坏,但列表的数据不受保护.例如:
L[0] += 1
Run Code Online (Sandbox Code Playgroud)
如果另一个线程执行相同的操作,则不保证实际将L [0]增加1,因为+=它不是原子操作.(非常,很少有Python中的操作实际上是原子的,因为它们中的大多数都可以导致调用任意Python代码.)您应该使用队列,因为如果您只使用不受保护的列表,您可能会因为种族而获取或删除错误的项目条件.
dot*_*hen 80
为了澄清托马斯的优秀答案中的一点,应该提到的append() 是线程安全.
这是因为一旦我们写入数据,就不会担心被读取的数据会在同一个地方.该操作不读取数据,只将数据写入列表.append()
Jon*_*han 36
这是一个全面但非详尽的list操作示例列表,以及它们是否是线程安全的.希望能得到关于答案obj in a_list的语言结构在这里.
| 归档时间: |
|
| 查看次数: |
80286 次 |
| 最近记录: |