_thread模块

Python调用_thread模块中的start_new_thread()函数产生新线程。
start_new_thread(function, args[, kwargs])
其中,function为线程函数;args为传递给线程的参数,必须是tuple类型;kwargs为可选选参数。
_thread模块除了产生线程外,还提供基本同步数据结构锁对象(lock object,也叫原语锁、简单锁、互斥锁、互斥量、二值信号量)。同步原语与线程管理是密不可分的

#! /usr/bin/evn python
#-*- coding:utf-8 -*-

import _thread
from time import sleep
from datetime import datetime

date_time_format="%y-%M-%d %H:%M:%S"

def date_time_str(date_time):
    return datetime.strftime(date_time,date_time_format)

def loop_one():
    print('+++线程一开始于:',date_time_str(datetime.now()))
    print('线程一休眠4秒')
    sleep(4)
    print('+++线程一休眠结束于:',date_time_str(datetime.now()))

def loop_two():
    print('+++线程二开始于:',date_time_str(datetime.now()))
    print('线程二休眠2秒')
    sleep(2)
    print('+++线程二休眠结束于:',date_time_str(datetime.now()))

def main():
    print('-----所有线程开始时间:',date_time_str(datetime.now()))
    _thread.start_new_thread(loop_one,())
    _thread.start_new_thread(loop_two,())
    sleep(6)
    print('-----所有线程结束时间:',date_time_str(datetime.now()))

if __name__=='__main__':
    main()

执行结果:

-----所有线程开始时间: 17-09-04 17:09:48
+++线程一开始于: 17-09-04 17:09:48 
+++线程二开始于: 17-09-04 17:09:48
线程一休眠4秒
线程二休眠2秒
+++线程二休眠结束于: 17-09-04 17:09:50
+++线程一休眠结束于: 17-09-04 17:09:52
-----所有线程结束时间: 17-09-04 17:09:54

_thread模块提供了简单的多线程机制,两个循环并发执行,总的运行时间为最慢的线程的运行时间(主线程6秒),而不是所有线程的运行时间总和。start_new_thread()要求至少传入两个参数,即使想要运行的函数不需要参数也要传入一个空元组。
sleep(6)是让主线程停下来。主线程一旦运行结束,就关闭运行着的所有子线程。这可能造成主线程过早或过晚退出,这时就要使用线程锁,主线程可以在所有子线程都退出后在立即退出。
使用线程锁:

#! /usr/bin/evn python
#-*- coding:utf-8 -*-

import _thread
from time import sleep
from datetime import datetime

loops=[4,2]
date_time_format="%y-%M-%d %H:%M:%S"

def date_time_str(date_time):
    return datetime.strftime(date_time,date_time_format)

def loop(n_loop,n_sec,lock):
    print('线程(',n_loop,')开始执行:',date_time_str(datetime.now()),',先休眠(',n_sec,')秒')
    sleep(n_sec)
    print('线程(',n_loop,')休眠结束,结束于:',date_time_str(datetime.now()))
    lock.release()

def main():
    print('---所有线程开始执行……')
    locks=[]
    n_loops=range(len(loops))

    for i in n_loops:
        lock=_thread.allocate_lock()
        lock.acquire()
        locks.append(lock)

    for i in n_loops:
        _thread.start_new_thread(loop,(i,loops[i],locks[i]))

    for i in n_loops:
        while locks[i].locked():pass

    print('———所有线程执行结束:',date_time_str(datetime.now()))

if __name__=='__main__':
    main()


❤️


5804969-64ca917b7b70f881.jpg
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值