day18总结

进程:处于运行状态的应用程序(工厂)

线程:执行任务的最小单元(工人)

每个进程默认都有一个线程,这个线程叫主线程,其他的线程都叫子线程
python中threading模块专门提供和线程相关的类和方法

python3通过两个标准库_thread 和 threading 提供对线程的支持。
_thread 提供了低级别的、原始的线程以及一个简单的锁
threading 模块除了包含 _thread 模块中的所有方法外,还提供的其他方法

1.线程模块

threading.currentThread() -- 返回当前的线程变量
threading.enumerate(): 返回一个包含正在运行的线程的list。正在运行指线程启动后、结束前,不包括启动前和终止后的线程。
threading.active_count(): 返回正在运行的线程数量,与len(threading.enumerate())有相同的结果。

除了使用方法外,线程模块同样提供了Thread类来处理线程,Thread类提供了以下方法:
run(): 用以表示线程活动的方法。
start():启动线程活动。
join([time]): 如果希望某个任务是在某个线程结束后才执行,那就将这个任务的开始代码放在对应的线程对象调用join方法的后面

isAlive(): 返回线程是否活动的。
getName(): 返回线程名。
setName(): 设置线程名。

2.创建自己的线程类

1)声明一个类继承Thread
2)实现run方法,这个方法中的任务就是需要在子线程中执行的任务

注意:一个进程中如果有多个线程,程序会在所有的线程都结束的任务结束。发生异常和崩溃其实崩溃的是线程

  1. 用子类直接创建线程对象
  2. 通过start去执行子线程中的任务
    注意:不能通过线程对象去直接调用run方法,因为这样调用不会在子线程中执行任务

3.线程共享数据时遇到的问题和解决办法

1.问题
当多个线程同时对一个数据进行读写操作,可能会出现一个线程刚把数据读出来还未来得及写进去,另外一个线程进行读操作的数据操作,会造成数据紊乱

2.解决 - 加锁(Thread的lock类)
1)保证每个数据对应一个锁对象
2)操作数据前加锁,数据操作完成后解锁

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

推荐阅读更多精彩内容

  • 一、Python简介和环境搭建以及pip的安装 4课时实验课主要内容 【Python简介】: Python 是一个...
    _小老虎_阅读 5,820评论 0 10
  • 线程 操作系统线程理论 线程概念的引入背景 进程 之前我们已经了解了操作系统中进程的概念,程序并不能单独运行,只有...
    go以恒阅读 1,676评论 0 6
  • 写在前面的话 代码中的# > 表示的是输出结果 输入 使用input()函数 用法 注意input函数输出的均是字...
    FlyingLittlePG阅读 2,938评论 0 8
  • 一文读懂Python多线程 1、线程和进程 计算机的核心是CPU,它承担了所有的计算任务。它就像一座工厂,时刻在运...
    星丶雲阅读 1,496评论 0 4
  • 1.进程和线程 1)import threading # 专门提供和线程相关的操作2)每个进程默认都有一个线...
    蓝色骨头_3f91阅读 116评论 0 0