zoukankan      html  css  js  c++  java
  • python的thread模块作用

    线程

    python的thread模块是比较底层的模块,python的threading模块是对thread做了一些包装的,可以更加方便的被使用

    1. 使用threading模块

    单线程执行

    import threading
    import time
    
    def hello_for():
        print("你好 世界, 你好  中国")
        time.sleep(1)
    
    if __name__ == "__main__":
        for i in range(5):
            t = threading.Thread(target=hello_for)
            t.start() #启动线程,即让线程开始执行

    运行结果:

    多线程执行

    import threading
    import time
    
    def hello_for():
        print("你好 世界, 你好  中国")
        time.sleep(1)
    
    if __name__ == "__main__":
        for i in range(5):
            t = threading.Thread(target=hello_for)
            t.start() #启动线程,即让线程开始执行

    运行结果:

    说明

    1. 可以明显看出使用了多线程并发的操作,花费时间要短很多
    2. 当调用start()时,才会真正的创建线程,并且开始执行

    2. 主线程会等待所有的子线程结束后才结束

    import threading
    from time import sleep,ctime
    
    def sing():
        for i in range(3):
            print("正在唱歌...%d"%i)
            sleep(1)
    
    def dance():
        for i in range(3):
            print("正在跳舞...%d"%i)
            sleep(1)
    
    if __name__ == '__main__':
        print('---开始---:%s'%ctime())
    
        t1 = threading.Thread(target=sing)
        t2 = threading.Thread(target=dance)
    
        t1.start()
        t2.start()
    
        print('---结束---:%s'%ctime())

    运行结果:

    3. 查看线程数量

    import threading
    from time import sleep,ctime
    
    def sing():
        for i in range(3):
            print("正在唱歌...%d"%i)
            sleep(1)
    
    def dance():
        for i in range(3):
            print("正在跳舞...%d"%i)
            sleep(1)
    
    if __name__ == '__main__':
        print('---开始---:%s'%ctime())
    
        t1 = threading.Thread(target=sing)
        t2 = threading.Thread(target=dance)
    
        t1.start()
        t2.start()
    
        while True:
            length = len(threading.enumerate())
            print('当前运行的线程数为:%d'%length)
            if length<=1:
                break
    
            sleep(0.5)

    运行结果:

  • 相关阅读:
    BZOJ2061 : Country
    BZOJ3591: 最长上升子序列
    BZOJ4356 : Ceoi2014 Wall
    BZOJ2159 : Crash 的文明世界
    BZOJ2149 : 拆迁队
    BZOJ2739 : 最远点
    BZOJ4068 : [Ctsc2015]app
    BZOJ4361 : isn
    BZOJ4404 : [Neerc2015]Binary vs Decimal
    BZOJ4402 : Claris的剑
  • 原文地址:https://www.cnblogs.com/aydenwang/p/9427862.html
Copyright © 2011-2022 走看看