1. 介绍
我正在使用PyQt5
Python 3.7 开发一个多线程应用程序,为此我依赖QThread
.
现在假设我有一个派生自QObject
. 在该类中,我定义了一个用 注释的函数@pyqtSlot
:
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
import threading
...
class Worker(QObject):
def __init__(self):
super().__init__()
return
@pyqtSlot()
def some_function(self):
...
return
在其他一些代码中,我将其实例化Worker()
并移至新线程,如下所示:
my_thread = QThread()
my_worker = Worker()
my_worker.moveToThread(my_thread)
my_thread.start()
QTimer.singleShot(100, my_worker.some_function)
return
通常,some_function()
现在应该在my_thread
. 那是因为:
- 我已将
Worker()
对象推到my_thread
. - 当命令
my_thread
开始时,我实际上已经在那个线程中产生了一个新的 Qt 事件循环。该my_worker
对象存在于这个事件循环中。它的所有插槽都可以接收一个事件,该事件在此事件循环中执行。 some_function()
被正确注释为@pyqtSlot()
. 单次计时器挂钩到此插槽并触发一个事件。多亏了 Qt-event-loop inmy_thread
,插槽有效地执行了它的代码my_thread
。
2. 我的问题
我的问题是关于嵌套函数(也称为“内部函数”)。考虑一下:
class Worker(QObject):
def __init__(self):
super().__init__()
return
def some_function(self):
...
@pyqtSlot()
def some_inner_function():
...
return
return
如您所见,some_inner_function()
被注释为@pyqtSlot
. 它的代码是否也会在Worker()
-object 所在的线程中运行?
3.旁注:如何hook到内部函数
您可能想知道我如何将某些东西与内部函数挂钩。好吧,考虑以下几点:
class Worker(QObject):
def __init__(self):
super().__init__()
return
def some_function(self):
@pyqtSlot()
def some_inner_function():
# Will this code run in `my_thread`?
...
return
# some_function() will run in the main thread if
# it is called directly from the main thread.
QTimer.singleShot(100, some_inner_function)
return
如果您some_function()
直接从主线程调用,它将(不幸地)在主线程中运行。如果没有正确使用信号槽机制,您将不会切换线程。
内部的单发计时器some_function()
钩住some_inner_function()
并开火。内部函数是否会执行my_thread
(假设Worker()
-object 已分配给my_thread
)?