python中list线程安全问题

严格意义上说,只有操作才有是否安全的定义,因为线程是否安全,针对的不是对象,而是操作

如果我们指这样的操作L[0] = L[0] + 1,它当然不是一个原子操作,不加以保护就会导致线程不安全,而L.append(i)这样的操作则是线程安全的。

举个list线程不安全的例子

import threading
import time

zero = [3]


def change_zero():
    global zero
    for i in range(3000000):
        # zero += 1
        # zero -= 1
        zero[0] = zero[0] + 1
        zero[0] = zero[0] - 1


th1 = threading.Thread(target=change_zero)
th2 = threading.Thread(target=change_zero)
th1.start()
th2.start()
th1.join()
th2.join()
print(zero)

运行会发现,每次结果不一样,为啥,是因为zero[0] = zero[0] + 1这个操作不是原子性的,分解下来是这样

x = zero[0] + 1
zero[0] = x

有可能赋值给x完后,GIL锁就给了其他线程,此时会产生线程不安全的情况

如何做到线程安全呢?

import threading
import time

zero = [3]
lock = threading.Lock()


def change_zero():
    global zero
    for i in range(3000000):
        # zero += 1
        # zero -= 1
        with lock:
            zero[0] = zero[0] + 1
            zero[0] = zero[0] - 1


th1 = threading.Thread(target=change_zero)
th2 = threading.Thread(target=change_zero)
th1.start()
th2.start()
th1.join()
th2.join()
print(zero)

加上一把锁就行,强行保证了操作的原子性,但是,会降低执行效率

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python的多线程,有一个重要的概念是全局解释器锁(Global Interpreter Lock,GIL)。引用\[2\]提到,Python的GIL负责Python解释器的线程安全,它保证了在任何时刻只有一个线程在执行字节码。这意味着,即使在多核CPU上,Python的多线程机制也只能同时执行一个线程。因此,对于CPU密集型任务,使用多线程并不能真正提高程序的运行效率。 然而,对于I/O密集型任务,多线程仍然可以提供一定的性能优势。因为当一个线程在等待I/O操作完成时,其他线程可以继续执行,从而充分利用了CPU的空闲时间。此外,Python还提供了线程池和协程等机制,可以进一步提高I/O密集型任务的效率。 在多线程编程,需要注意线程安全性和共享资源的竞争问题。由于多个线程可能同时访问和修改共享资源,可能会导致数据不一致或者竞争条件的发生。为了解决这个问题,可以使用锁(Lock)或者其他同步机制来保护共享资源的访问。 总结来说,Python的多线程机制在CPU密集型任务上并不能真正提高程序的运行效率,但在I/O密集型任务上仍然可以提供一定的性能优势。在多线程编程,需要注意线程安全性和共享资源的竞争问题,并使用适当的同步机制来保护共享资源的访问。 #### 引用[.reference_title] - *1* *2* *3* [Python多线程详解](https://blog.csdn.net/qq_38236620/article/details/127474040)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值