python 一个简单的线程调度

Posted tianyb

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python 一个简单的线程调度相关的知识,希望对你有一定的参考价值。

一、基本概念

线程

在一个进程内部要同时运行多个子任务,我们将进程内的子任务称为线程,一个进程内至少包括一个线程,线程是最小的执行单元,没有自己独立的堆栈

线程调度

使用算法是线程按一定的顺序执行

二、完成简单的线程调度

题目要求

有两个线程分别输出0,2,4,6,8和1,3,5,7,9,编写程序使得输出顺序是0,1,2,3,4,5,6,7,8,9

源代码


import threading
import time
cond = threading.Condition()
def func1(num):
    print("子线程(%s)开始执行" % (threading.current_thread().name))
    with cond:
        for i in range(num,10,2):
            time.sleep(0.5)
            print(i)
            cond.wait()#等待,当前线程停止,其他线程执行
            cond.notify()
    print("子线程(%s)结束执行" % (threading.current_thread().name))

def func2(num):
    print("子线程(%s)开始执行" % (threading.current_thread().name))
    with cond:
        for i in range(num, 10, 2):
            time.sleep(0.5)
            print(i)
            cond.notify()#通知上面其他的线程自己已经执行完毕,然后自己等待
            cond.wait()#自己等待
    print("子线程(%s)结束执行" % (threading.current_thread().name))

if __name__ == ‘__main__‘:
    print("主线程(%s)开始执行" % (threading.current_thread().name))
    #主线程
    t1 = threading.Thread(target=func1,name=‘线程1‘,args=(0,))
    t2 = threading.Thread(target=func2, name=‘线程2‘,args=(1,))
    t1.start()
    t2.start()
    print("主线程(%s)结束执行" % (threading.current_thread().name))

以上是关于python 一个简单的线程调度的主要内容,如果未能解决你的问题,请参考以下文章

python threading超线程使用简单范例的代码

python之进程,线程,协程简单理解

线程学习知识点总结

调度嵌入式python进程

了解多线程

事件调度线程是如何工作的?