进程、线程
进程:就是一个程序,运行在系统之上,那么便称之为这个程序为一个运行进程,并分配进程ID方便系统管理
线程:线程归属于进程的,一个进程可以开启多个线程,执行不同的工作,是进程的实际工作最小单位
操作系统中可以运行多个进程,即多任务运行
一个进程内可以运行多个线程,即多线程运行
注意点
进程之间是内存隔离的,即不同的进程拥有各自各的内存空间。这就类似于不同的公司拥有不同的办公场所
线程之间是内存共享的,线程是属于进程的,一个进程内的多个线程之间是共享这个进程所拥有的内存空间的。这就好比,公司员工之间是共享公司的办公场所
并行执行
并行执行的意思指的是同一时间做不同的工作
进程之间就是并行执行的,操作系统可以同时运行好多程序,这些程序都是在并行执行
除了进程外,线程其实也是可以并行执行的。
也就是比如一个python程序,其实是完全可以做到:
- 一个线程在输出:你好
- 一个线程在输出:Hello
这样的行为称之为:多线程并行执行
threading模块
python多线程可以通过threading模块来实现
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()