python的多线程编程

线程

在 Python 中,线程 分为三种形式,即主线程、守护线程和非守护线程。主线程也叫 main 线程,主线程不是守护线程。

  • 主线程退出,进程等待所有子线程执行完毕后才结束
  • 主线程结束后进程不等待守护线程完成,守护线程连同主线程立即结束

根据特性分析,守护进程一般运行着可以随时被结束的程序。
而非守护进程,一般运行着不能随时结束,需要处理善后的程序。例如释放资源、或者备份数据。

守护线程

import threading
def reader:
	pass

thread_read = threading.Thread(target=reader)
thread_read.setDaemon(True)        # setDaemon(True),则为守护进程

非守护线程

与守护线程相反,不调用setDaemon(True)则说明该线程非守护线程。生命周期与主线程无关。

主线程

主线程中创建子线程,然后各自运行各自的。那么各自线程的结束时机可能有:

  • 主线程先结束,其他线程继续运行。
  • 主线程调用join()方法,原地阻塞。等待指定线程结束,主线程才能往下运行。
  • 最后:等所有线程(主+守护+非守护)都结束,进程退出

线程安全

通常有两种方式,锁和信号量。在说这两个东西之前,先说两个概念

  • 临界资源:是同一时刻仅允许一个进程/线程使用的共享资源。各进程/线程采取互斥的方式,实现共享的资源称作临界资源。临界资源是资源。
  • 临界区:每个进程/线程中访问临界资源的那段代码称为临界区。临界区是代码,通常会在临界区的入口和出口加锁
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值