主线程主要是进行一些界面操作。子线程就进行一些耗时的获取数据、处理数据等操作,然后返回数据给主线程,让主线程更新 UI,这样才不会让程序出现无响应的现象。
如果把获取数据的操作放在主线程,那么主线程就会一直等待数据,这个时候程序就不可和用户进行交互,体验非常差。
import threading
from time import sleep
def child_thread_func(str, main_thread_func):
sleep(3) # 子线程暂停 3 秒,模拟获取数据的操作
data = 'xxx'
# 在子线程中回调主线程的函数,更新界面
main_thread_func(data)
print(str)
def main():
# 通过 target=函数名 的方式定义子线程
# 通过 target 指定子线程要执行的任务。可以通过 args=元组 来指定该函数的参数
t1 = threading.Thread(target=child_thread_func, args=("AAA", update_UI))
# start 之后,子线程开始执行,主线程也会继续执行,不会等待
t1.start() # 子线程执行
print("主线程")
# 当子线程没有结束时,主线程也不会结束
# 当主线程结束后,所有的子线程也会结束。
def update_UI(data):
print("在主线程中更新 UI 成功:" + data)
if __name__ == "__main__":
main()
import threading
# 通过类定义子线程。 继承threading.Thread类
from time import sleep
class MyThread(threading.Thread):
# 开启子线程时,会自动执行run函数
def __init__(self, str, callback):
super().__init__()
self.str = str
self.callback = callback
def run(self):
# 模拟耗时操作,获取数据
sleep(3)
print(self.str)
data = '在子线程获取到的数据'
self.callback(data)
def main():
t = MyThread("abc", update_UI) # 实例化自定义的子线程
t.start() # 开启子线程
print("main")
def update_UI(data):
print(data)
if __name__ == '__main__':
main()