既然Python解释器是单线程的,还有进行多线程编程的必要吗?

谢邀,我们来聊聊Python的GIL问题。
CPython(标准的python实现)有一个名为GIL(全局解释器锁)的东西,它阻止两个线程在同一个程序中同时执行。 有些人对此感到不安,而其他人则狠狠地

本文最后更新时间:  2023-02-25 17:34:15

谢邀,我们来聊聊Python的GIL问题。

CPython(标准的python实现)有一个名为GIL(全局解释器锁)的东西,它阻止两个线程在同一个程序中同时执行。 有些人对此感到不安,而其他人则狠狠地为此辩护。 但是,有一些解决方法,像Numpy这样的库通过在C中运行外部代码来绕过这个限制。

何时使用线程与进程?

进程加速了CPU密集型的Python操作,因为它们受益于多个内核并避免使用GIL。

线程最适合IO任务或涉及外部系统的任务,因为线程可以更有效地组合他们的工作。 进程需要挑选他们的结果来组合它们需要时间。

由于GIL,线程在python中没有为CPU密集型任务提供任何好处。而对于像Dot Product这样的某些操作,Numpy可以解决Python的GIL并且并行执行代码。

I/O的多线程使用

应用程序的大部分时间都花在I/O上。无论是磁盘I/O还是网络I/O。

例如,对于Web应用程序,大多数情况下是处理数据库。因此,在大多数现代应用程序中,最大的瓶颈是I/O。以下是开启4个线程后效果,实际上效果还是很显著的。

这意味着应用程序大部分都在等待,因此即使python没有GIL,也不是所有应用程序都会一直运行(使用cpu,因为它们将等待I/O完成)。

所以,在大多数应用程序线程在I / O上等待的情况下,其他线程可以获取CPU,从而提高性能。如果python没有多线程,那么其他一些线程无法获得cpu因此浪费时间。现在至少当一个线程正在等待I/O时(大部分应用程序都是这种情况),其余的线程都可以工作,那么多线程还是有它存在的必要,所以这就是我们没有看到GIL所拥有问题的原因。

当然如果你的应用程序是CPU密集型的,那么在python中确实没有太多的线程可以提供使用。

我会在这里发布所有与科技、科学有关的有趣文章,欢迎订阅我的头条号。偶尔也回答有趣的问题,有问题可随时在评论区回复和讨论。

(码字不易,若文章对你帮助可点赞支持~)

 1/2    1 2 下一页 尾页
温馨提示:内容均由网友自行发布提供,仅用于学习交流,如有版权问题,请联系我们。