python的线程并发

本文介绍了如何使用Python的threading模块创建线程,通过MyThread类实例化并启动线程活动。作者详细讲解了`run()`方法和`start()`方法的区别,以及`join()`方法的使用,展示了如何并发执行多个循环任务。
摘要由CSDN通过智能技术生成

使用threading这个高级模块
run(): 用以表示线程活动的方法。
start():启动线程活动。
join([time]): 等待至线程中止。这阻塞调用线程直至线程的join() 方法被调用中止-正常退出或者抛出未处理的异常-或者是可选的超时发生。

#!/usr/bin/env python3
# -*- coding: utf-8 -*-
# @Time:2021/3/27 10:55
# @Author:九九的金金子
import logging
import threading
from time import ctime, sleep

logging.basicConfig(level=logging.INFO)

loops = [1, 2]

# 我们可以通过直接从 threading.Thread 继承创建一个新的子类,并实例化后调用 start() 方法启动新线程,即它调用了线程的 run() 方法:
class MyThread(threading.Thread):
    # 改写线程
    def __init__(self, func, args, name=''):
        threading.Thread.__init__(self)
        self.func = func
        self.args = args
        self.name = name

    def run(self):
        self.func(*self.args)


def loop(nloop, nsec):
    logging.info("start loop " + str(nloop) + "at" + ctime())
    sleep(nsec)
    logging.info("end loop " + str(nloop) + "at" + ctime())


def main():
    logging.info("star all at " + ctime())
    threads = []
    nloops = range(len(loops))
    for i in nloops:
        # 创建新线程
        t = MyThread(loop, (i, loops[i]), loop.__name__)
        threads.append(t)
    for i in nloops:
        # 并发执行
        threads[i].start()
    for i in nloops:
        threads[i].join()
    logging.info("end all at " + ctime())


if __name__ == '__main__':
    main()

执行结果:

INFO:root:star all at Sat Mar 27 12:17:20 2021
INFO:root:start loop 0atSat Mar 27 12:17:20 2021
INFO:root:start loop 1atSat Mar 27 12:17:20 2021
INFO:root:end loop 0atSat Mar 27 12:17:21 2021
INFO:root:end loop 1atSat Mar 27 12:17:22 2021
INFO:root:end all at Sat Mar 27 12:17:22 2021
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值