进程、线程

如果学过计算机操作系统的话,对这两个的概念应该是理解的

我们打开任务管理器,发现有很多进程

现代操作系统比如Mac OS X,UNIX,Linux,Windows等,都是支持"多任务"的操作系统


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

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


进程就好比一家公司,是操作系统对程序进行运行管理的单位

线程就好比公司的员工,进程可以有多个线程(员工),是进程实际的工作者


操作系统中可以运行多个进程,即多任务运行

一个进程内可以运行多个线程,即多线程运行


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

线程之间是内存共享的,线程是属于进程的,一个进程内的多个线程之间是共享这个进程所拥有的内存空间的。这就好比,公司员工之间是共享公司的办公场所

并行执行

并行执行的意思指的是同一时间做不同的工作

进程之间就是并行执行的,操作系统可以同时运行好多程序,这些程序都是在并行执行

除了进程外,线程其实也是可以并行执行的

也就是比如一个Python程序,其实是完全可以做到:

  • 一个线程在输出:你好
  • 一个线程在输出:Hello

像这样一个程序在同一时间做两件乃至多件不同的事情,我们就称之为:多线程并行执行

多线程编程

绝大多数编程语言,都允许多线程编程,Python也不例外

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

格式:

import threading
thread_obj = threading.Thread([group [, target [, name [, args [, kwargs]]]]])
- group:暂时无用,未来功能的预留参数
- target:执行的目标任务名
- args:以元组的方式给执行任务传参
- kwargs:以字典的方式给执行任务传参
- name:线程名,一般不用设置

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

示例:

import time

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

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

if __name__ == '__main__':
    sing()
    dance()

直接执行只有唱歌,但我们想让其同时唱歌同时跳舞,这就需要多线程了

import threading
import time

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()

传递参数

import threading
import time

def sing(msg):
    while True:
        print(msg)
        time.sleep(1)

def dance(msg):
    while True:
        print(msg)
        time.sleep(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()