多任务-线程

Posted snailon

tags:

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

  • 并发:指的是任务数多余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)

主线程和子线程

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

 

以上是关于多任务-线程的主要内容,如果未能解决你的问题,请参考以下文章

NodeJs多线程、多进程、定时任务

多线程

多任务编程进程线程

python多线程实现多任务

Python进阶:利用线程实现多任务

1.多线程-了解多线程与高并发