进程,是计算机中程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。线程是程序执行流的最小单位,是进程的一个实体,是被系统独立调度和分派的基本单位。一个进程可以包含多个线程,进程和线程是一对多的关系。线程自己不拥有系统资源,在单个程序中同时运行多个线程完成不同的工作,称为多线程。线程和进程的区别在于,子进程和父进程有不同的代码和数据空间,而多个线程则共享数据空间,每个线程有自己的执行堆栈和程序计算器为其执行上下文。
关于CPU、进程和线程,可以用一个比喻形象来描述:计算机核心是CPU,像一个工厂,进程是工厂里面的车间,负责完成某一项任务。工厂资源有限,只能在某个时刻支撑某个车间运转,所以,CPU在一段时间内是不断切换进程工作的。一个车间内有很多工人,相当于线程,共享着车间的空间和资源,每个线程都为了同一个任务而工作。
下面将通过代码介绍线程、进程的应用:
1、单线程(执行有先后)
from time import ctime,sleep
#定义说和写
def talk():
print("we talk:%r,%r" %(content,ctime()))
sleep(2)
def write():
print("we write:%r,%r" % (content, ctime()))
sleep(2)
if __name__=='__main__':
talk()
write()
2、多线程(并发进行)
from time import ctime,sleep
import threading
#定义说和写
def talk(content,loop):
for i in range(loop):
print("we talk:%r,%r" %(content,ctime()))
sleep(2)
def write(content, loop):
for i in range(loop):
print("we write:%r,%r" % (content, ctime()))
sleep(2)
#定义和装载说和写的线程
threads=[]
t1=threading.Thread(target=talk,args=('hello',2))
threads.append(t1)
t2=threading.Thread(target=write,args=('hi',2))
threads.append(t2)
#执行多线程
if __name__=='__main__':
for t in threads:
t.start()
for t in threads:
t.join()
3、多进程
import multiprocessing
from time import ctime,sleep
#定义说和写
def talk(content,loop):
for i in range(loop):
print("we talk:%r,%r" %(content,ctime()))
sleep(2)
def write(content, loop):
for i in range(loop):
print("we write:%r,%r" % (content, ctime()))
sleep(2)
process=[]
p1=mutiprocessing.Process(target=talk,args=('hello,2'))
process.append(p1)
p2=mutiprocessing.Process(target=write,args=('hi,2'))
process.append(p2)
#执行多线程
if __name__=='__main__':
for t in process:
t.start()
for t in process:
t.join()