多线程

1.什么是进程

一个正在运行的应用程序就是一个进程.系统会给每一个进程分配一个独立的内存区域,用来保存程序运行过程中产生的数据,当进程结束的时候,这个内存区域会自动销毁

2.什么是线程

进程想要执行任务,就必须要有线程.每个进程都默认有一个线程,这个线程叫主线程;其他的线程叫子线程,程序都是默认在主线程中执行的
一个线程中执行多个任务,任务是串行执行的(一个一个地执行)
一个进程中如果有多个线程,多线程执行不同任务的时候是并行(同时执行)

3.python中怎么使用多线程

python通过内置的threading模块来提供多线程相关技术;
其中有一个Thread类,这个类的对象就是线程对象


创建线程的方法

1.直接创建线程类的对象
语法:
线程对象 = Thread(target=函数,args =参数) - 创建一个线程对象,并且返回
说明:
函数 - function类型的变量;这个函数的函数体会在子线程中执行
参数 - 元组;参数会给target对应的函数(单个元组用括号括起来,还要有逗号)
让子线程开始执行任务
线程对象.start() - 开始执行子线程中的任务
补充:某个线程出现异常,是线程直接结束;进程不一定结束,所有的线程结束,进程才会结束


2.创建线程子类

    1. 声明一个类继承自Thread
    1. 重写run方法,这个方法中的任务就是需要在子线程中执行的任务
    1. 创建当前类的对象,就是线程对象
    1. 启动子线程
class DownloadThread(Thread):
    def __init__(self, film):
        super().__init__()
        self.film = film

    def run(self):
        print('%s开始下载...' % self.film)
        time1 = randint(3, 10)
        time.sleep(time1)
        print('%s下载结束,总耗时%d秒' % (self.film, time1))

创建线程对象

t1 = DownloadThread('霸王别姬')
t2 = DownloadThread('海贼王')

线程对象 = 类名(参数) - 类名是自己定义的继承了Thread类的这个类的名字,参数是类的对象属性,所以需要传参
启动线程

  • 线程对象调用start会自动在子线程中取调用run方法
  • 直接用线程对象调用run方法,run方法会在主线程中执行
start = time.time()   # 此时的时间
t1.start()
t2.start()
# 在子线程t1和t2中执行的
# 如果t1.run(),那么run方法会在主线程中执行

补充:join的用法
线程对象.join() -- 程序执行到这个地方会停下来(线程阻塞),直到线程对象中的任务执行完后才执行后面的语句

t1.join()
t2.join()
# print('t1结束')
end = time.time()  #此时的时间
print('总时间: ', end - start)  # 总时间 = 结束时间减去开始时间

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 进程和线程 进程 所有运行中的任务通常对应一个进程,当一个程序进入内存运行时,即变成一个进程.进程是处于运行过程中...
    胜浩_ae28阅读 5,170评论 0 23
  • Java多线程学习 [-] 一扩展javalangThread类 二实现javalangRunnable接口 三T...
    影驰阅读 3,007评论 1 18
  • 本文主要讲了java中多线程的使用方法、线程同步、线程数据传递、线程状态及相应的一些线程函数用法、概述等。 首先讲...
    李欣阳阅读 2,515评论 1 15
  •   一个任务通常就是一个程序,每个运行中的程序就是一个进程。当一个程序运行时,内部可能包含了多个顺序执行流,每个顺...
    OmaiMoon阅读 1,732评论 0 12
  • 读书过程中,我们总会使用很多的公式,像二元一次方程之类的,用公式的话会使得我们的计算变的简单。 在计算机中,Jav...
    App0ll0阅读 797评论 0 1