码迷,mamicode.com
首页 > 编程语言 > 详细

多任务-线程

时间:2019-09-05 18:25:50      阅读:105      评论:0      收藏:0      [点我收藏+]

标签:程序   odi   bre   import   方便   enumerate   sleep   coding   art   

  • 并发:指的是任务数多余cpu核数,通过操作系统的各种任务调度算法,实现用多个任务在同一时间段执行(实际上总有一些任务不在执行,因为切换任务的速度相当快,看上去一起执行而已)
  • 并行:指的是多核cpu情况下,多个任务的一些任务往往是在同一时间点执行的

1. 使用threading模块

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

多线程执行

#coding=utf-8
import threading
import time

def saySorry():
    print("亲爱的,我错了,我能吃饭了吗?")
    time.sleep(1)

if __name__ == "__main__":
    for i in range(5):
        t = threading.Thread(target=saySorry)
        t.start() #启动线程,即让线程开始执行

 

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

#coding=utf-8
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()

    #sleep(5) # 屏蔽此行代码,试试看,程序是否会立马结束?
    print(---结束---:%s%ctime())

3. 查看线程数量

#coding=utf-8
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)

主线程和子线程

默认存在的就是主线程,新创建出来的就是子线程。

 

多任务-线程

标签:程序   odi   bre   import   方便   enumerate   sleep   coding   art   

原文地址:https://www.cnblogs.com/snailon/p/11468507.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!