- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我对多线程在 Python 中是否有效有点困惑。
我知道有很多关于此的问题,并且我已经阅读了其中的很多问题,但我仍然感到困惑。根据我自己的经验,并且看到其他人在 StackOverflow 上发布了自己的答案和示例,我知道多线程在 Python 中确实是可能的。那么为什么大家一直说Python被GIL锁住了,一次只能运行一个线程呢?显然它确实有效。还是有什么我在这里没有理解的区别?
许多发帖者/受访者还不断提到线程是有限的,因为它不使用多核。但我想说它们仍然有用,因为它们同时工作,因此可以更快地完成组合工作负载。我的意思是,否则为什么会有 Python 线程模块呢?
更新:
感谢迄今为止的所有回答。我的理解是,多线程只会并行运行某些 IO 任务,但对于 CPU 密集型多核任务一次只能运行一个。
我不完全确定这在实际中对我意味着什么,所以我只举一个我想要多线程的任务类型的例子。例如,假设我想循环遍历一个很长的字符串列表,并且我想对每个列表项执行一些基本的字符串操作。如果我拆分列表,发送每个子列表以供新线程中的循环/字符串代码处理,并将结果发送回队列中,这些工作负载是否会大致同时运行?最重要的是,理论上这会加快运行脚本所需的时间吗?
另一个例子可能是,如果我可以在四个不同的线程中使用 PIL 渲染并保存四张不同的图片,这比逐个处理图片更快吗?我想我真正想知道的是这个速度组件,而不是正确的术语是什么。
我也了解多处理模块,但我现在的主要兴趣是中小型任务负载(10-30 秒),因此我认为多线程会更合适,因为子进程启动速度可能很慢。
最佳答案
GIL 不会阻止线程。 GIL 所做的只是确保一次只有一个线程正在执行 Python 代码;控制仍然在线程之间切换。
GIL 所防止的是使用多个 CPU 核心或单独的 CPU 并行运行线程。
这仅适用于 Python 代码。 C 扩展可以并且确实释放了 GIL,以允许 C 代码的多个线程和一个 Python 线程跨多个内核运行。这扩展到由内核控制的 I/O,例如用于套接字读取和写入的 select()
调用,使 Python 在多线程多核设置中相当有效地处理网络事件。
许多服务器部署所做的就是运行多个 Python 进程,让操作系统处理进程之间的调度,以最大限度地利用 CPU 核心。您还可以使用multiprocessing
library如果适合您的用例,则可以处理来自一个代码库和父进程的跨多个进程的并行处理。
请注意,GIL 仅适用于 CPython 实现; Jython 和 IronPython 使用不同的线程实现(分别是 native Java VM 和 .NET 公共(public)运行时线程)。
直接解决您的更新问题:任何尝试使用纯 Python 代码从并行执行中获得速度提升的任务都不会看到加速,因为线程 Python 代码被锁定到一次执行一个线程。但是,如果混合使用 C 扩展和 I/O(例如 PIL 或 numpy 操作),则任何 C 代码都可以与一个事件 Python 线程并行运行。
Python 线程非常适合创建响应式 GUI,或者处理多个短 Web 请求,其中 I/O 比 Python 代码更成为瓶颈。它不适合并行计算密集型 Python 代码,请坚持使用 multiprocessing
模块来执行此类任务或委托(delegate)给专用的外部库。
关于python - Python 支持多线程吗?它可以加快执行时间吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26992428/
我想使用 ffmpeg 框架更改视频速度。我为此使用了这个命令: ffmpeg -y -i /storage/extSdCard/Video/1.avi -filter_complex [0:v]fp
我有以下数据数组,有 200 万个条目: [20965 1239 296 231 -1 -1 20976 1239 299 314 147 337 255
我正在使用 Oracle 数据库,并且想获取一个包含 3000 万条记录的表。 library(RODBC) ch <- odbcConnect("test", uid="test_user",
我在 android 上使用 FFmpeg 来: 1- 合并 3 个视频 2-添加音频 3-添加标志 4-修剪 3 个视频之一 5-改变输出的fps 我已经实现了正确的代码,但花了 30 分钟。对于(
我使用 GLPKMathProgInterface 和 JuMP 编写了一个程序来解决 Julia 中的线性程序。 Julia 代码由 python 程序调用,该程序通过多个命令行调用运行多个 Jui
我们使用 POV-Ray 每次运行生成大约 80 张图像,我们将这些图像拼接在一起形成两个移动的 GIF 文件(一个场景的两个 360 度 View )。我们正在寻找尽可能加快此镜像创建的方法(在 h
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
我将数据从一个数据库插入到另一个数据库,所以我有 2 个连接(Conn1 和 Conn2)。下面是代码(使用pypyodbc)。 import pypyodbc Conn1_Query = "SE
在我的应用程序中,我显示 EKEvents 列表,我想在 UITableView 中显示一个月的所有事件,每个部分包含各自的日期。嗯,这可行,我得到了我需要的所有数据,但获取速度非常慢。 问题在于事件
我有一个移动速度非常慢的传送带。我不知道什么JS脚本控制速度,我需要它来加速。无法从主题制作者那里获得任何帮助。任何建议都会非常有帮助。谢谢 页面: http://krankgolf2017.wpen
有没有办法加快这段代码的速度?我需要它来删除相同的内容并将其写入单元格,以强制其他 VBA 代码运行另一列上的代码。这就是它的作用,只是 super 慢。有时此表上有 2000 个条目/行。每个单元大
我正在开发一个相当大的程序,它再次从一个相当大的 Excel 电子表格中获取数据。由于一些奇怪的原因,加载这个大的 Excel 文件需要很长时间,我希望能以某种方式加快速度。我做了自己的研究并尝试了
我有下面的代码,将所有按钮(有 10 个)着色为灰色,以清除任何先前着色的按钮,然后将所选按钮着色为蓝色。基本上充当当前选择哪个按钮的指示器。我注意到代码现在需要一些时间才能通过这种修饰添加来运行,我
我有一个 LINQ 查询,它正在搜索包含大约 250,000 条记录的 SQL 表,并且仅搜索 2 个字段。这两个字段都已建立索引,但我发现它的运行速度仍然相当慢。 下面是代码,有人可以提出任何建议来
对于相对较大的 Pandas DataFrame(几十万行),我想创建一个应用函数结果的系列。问题是该功能不是很快,我希望它能以某种方式加快速度。 df = pd.DataFrame({ 'valu
这个问题在这里已经有了答案: Faster weighted sampling without replacement (3 个答案) 关闭 9 年前。 如何在 R 中加快概率加权采样。 # Let
在运行 PhantomJS 提供的 rasterize.js 示例时,我发现我必须等待 20 秒或更长时间才能生成网页图像。 有没有可能在不消耗大量资源的情况下加快速度的方法?我基本上希望快速生成从加
我正在开发一个相当大的程序,它再次从一个相当大的 Excel 电子表格中获取数据。由于一些奇怪的原因,加载这个大的 Excel 文件需要很长时间,我希望能以某种方式加快速度。我做了自己的研究并尝试了
我有下面的代码,将所有按钮(有 10 个)着色为灰色,以清除任何先前着色的按钮,然后将所选按钮着色为蓝色。基本上充当当前选择哪个按钮的指示器。我注意到代码现在需要一些时间才能通过这种修饰添加来运行,我
我有一个 Excel 工作簿,用户通过单击按钮导入文本文件。我的代码完全按照我的需要工作,但是在填写 H 列“阅读日期”时速度非常慢。将文本文件导入 Excel 工作表后,我的 Excel 工作簿如下
我是一名优秀的程序员,十分优秀!