关于python多线程的一些理解

关于多线程的一些理解

  1. 线程是操作系统能够进行运算调度的最小单位,它包含在进程之中,是进程中的最小运作单位。一条线程指的是进程中一个单一顺序的控制流,在一个进程中可以并发多个线程,每条线程并行执行不同的任务,这样就可以提高程序的执行效率。
    多线程有硬件和软件之分,硬件多线程需要特殊处理器的支持,这些处理器基本上是双核或多核处理器,包括x86和ARM等平台,也有少数单核双线程的处理器,比如SNB架构的赛扬G4x0等。硬件多线程可以更大限度的发挥处理器的运算能力,而软件多线程则是通过快速的在不同线程之间进行切换,由于时间间隔很短从而给人造成一种多个线程同时运行的假象。
    任务是指独立的应用程序,在简单的嵌入式系统中也可以是实现某种功能的子程序、程序模块等,和线程是完全不同的概念,任务是从应用目的或者说运行结果的角度定义的,线程则是操作系统或处理器硬件的一种结构,在多线程处理和多任务调度中需要使用到中断,中断在此可以理解为“乐队指挥的打拍子”,是协调多线程和多任务的基准,操作系统根据中断标志来切换不同的进程和任务。
    多线程、多任务和中断之间的关系可以简单的理解为多线程是为多任务服务的,有时也可以将单任务拆分后并发执行,目的都是为了提高运行效率,它们的执行和管理则都离不开中断。
    转自http://bbs.eeworld.com.cn/thread-371187-1-1.html

  2. join( ) 阻塞主线程
    join() 作用为阻塞主线程,即在子线程未返回的时候,主线程等待其返回然后再继续执行
    join不能与start在循环里连用
    以下为错误代码,代码创建了5个线程,然后用一个循环激活线程,激活之后令其阻塞主线程

threads = [Thread() for i in range(5)]
for thread in threads:
thread.start()
thread.join()
1
2
3
4
执行过程:

  1. 第一次循环中,主线程通过start函数激活线程1,线程1进行计算

  2. 由于start函数不阻塞主线程,在线程1进行运算的同时,主线程向下执行join函数

  3. 执行join之后,主线程被线程1阻塞,在线程1返回结果之前,主线程无法执行下一轮循环

  4. 线程1计算完成之后,解除对主线程的阻塞

  5. 主线程进入下一轮循环,激活线程2并被其阻塞
    如此往复,可以看出,本来应该并发的五个线程,在这里变成了顺序队列,效率和单线程无异

    join的正确用法:使用两个循环分别处理start和join函数,即可实现并发

    threads = [Thread() for i in range(5)]
    for thread in threads:
    thread.start()
    for thread in threads:
    thread.join()


    作者:brucewong0516
    来源:CSDN
    原文:https://blog.csdn.net/brucewong0516/article/details/81050792
    版权声明:本文为博主原创文章,转载请附上博文链接!

  6. 关于多线程的锁https://www.cnblogs.com/guobaoyuan/p/6832470.html

  7. 多线程基础https://www.runoob.com/python/python-multithreading.html

  8. 多线程基础https://www.cnblogs.com/whatisfantasy/p/6440585.html

  9. 主线程阻塞https://www.cnblogs.com/wanghaihong200/p/8617657.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值