34.多线程

进程、线程、并行执行

进程:就是一个程序,运行在系统之上,那么便称之这个程序为一个运行进程,并分配进程ID方便系统管理

线程:线程是归属于进程的,一个进程可以开启多个线程,执行不同的工作,是进程的实际工作最小单位

注意点:

进程之间是内存隔离的,即不同的进程拥有各自的内存空间,这就类似于不同的公司拥有不同的办公场所

线程之间是内存共享的,线程是属于进程的,一个进程内的多个线程之间是共享这个进程拥有的内存空间的

并行执行:并行执行的意思指的是同一时间做不同的工作,进程之间就是并行执行的,操作系统可以同时并行运行很多程序

除了进程外,线程其实也是可以并行执行的,像这样一个程序在同一时间做两件乃至多件不同的事情,称之为:多线程并行执行

多线程编程

Python的多线程可以通过threading模块来实现

threading 模块

import threading

thread_obj = threading.Thread([group [, target [, name [, args [, kwargs]]]]])

  • group: 暂时无用,未来功能的预留参数
  • target: 执行的目标任务名
  • args: 以元组的方式给执行的任务传参
  • kwargs: 以字典方式给执行任务传参
  • name: 线程名,一般不用设置

启动线程,让线程开始工作: thread_obj.start()

import time, threading

def sing():
    while True:
        print("我在唱歌,啦啦啦。。。")
        time.sleep(1)

def dance():
    while True:
        print("我在跳舞,呱呱呱。。。")
        time.sleep(1)

if __name__ == '__main__':
    sing_thread = threading.Thread(target=sing)
    dance_thread = threading.Thread(target=dance)
    sing_thread.start()
    dance_thread.start()

# sing()
# dance()
# 我在唱歌,啦啦啦。。。
# 我在唱歌,啦啦啦。。。
# 我在唱歌,啦啦啦。。。
我在跳舞,呱呱呱。。。
我在唱歌,啦啦啦。。。
我在跳舞,呱呱呱。。。
我在唱歌,啦啦啦。。。
我在唱歌,啦啦啦。。。
我在跳舞,呱呱呱。。。
我在唱歌,啦啦啦。。。
我在跳舞,呱呱呱。。。
我在唱歌,啦啦啦。。。
我在跳舞,呱呱呱。。。

需要传参的话可以通过:

  • args参数通过元组(按参数顺序)的方式传参
  • 或使用kwargs参数用字典的形式传参
import time, threading

def sing(msg):
    i = 0
    while i <= 3:
        print(msg)
        time.sleep(1)
        i += 1

def dance(msg):
    i = 0
    while i <= 3:
        print(msg)
        time.sleep(1)
        i += 1

if __name__ == '__main__':
    sing_thread = threading.Thread(target=sing, args=("我要唱歌,哈哈哈。。。", ))
    dance_thread = threading.Thread(target=dance, kwargs={"msg": "我在跳舞,啦啦啦。。。"})
    sing_thread.start()
    dance_thread.start()
我要唱歌,哈哈哈。。。
我在跳舞,啦啦啦。。。

我要唱歌,哈哈哈。。。
我在跳舞,啦啦啦。。。
我要唱歌,哈哈哈。。。
我在跳舞,啦啦啦。。。
我要唱歌,哈哈哈。。。我在跳舞,啦啦啦。。。