python+selenium自动化测试-10进程与线程

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/qq_24601279/article/details/102646049

进程,是计算机中程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。线程是程序执行流的最小单位,是进程的一个实体,是被系统独立调度和分派的基本单位。一个进程可以包含多个线程,进程和线程是一对多的关系。线程自己不拥有系统资源,在单个程序中同时运行多个线程完成不同的工作,称为多线程。线程和进程的区别在于,子进程和父进程有不同的代码和数据空间,而多个线程则共享数据空间,每个线程有自己的执行堆栈和程序计算器为其执行上下文。

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

猜你喜欢

转载自blog.csdn.net/qq_24601279/article/details/102646049
今日推荐