Python基础知识学习-第12天

25_2.多线程之_thread模块

编写一段子程序,依次执行两次:

"""
单线程示例
"""
import time

def worker(n):
    print('子程序开始于:{}'.format(time.ctime()))
    time.sleep(n)
    print('子程序结束于:{}'.format(time.ctime()))

def main():
    print('[主程序开始于:{}'.format(time.ctime()))
    worker(4)
    worker(2)
    print('[主程序结束于:{}'.format(time.ctime()))

if __name__ == '__main__':
    main()

输出:

[主程序开始于:Sun Feb 23 16:25:22 2020
子程序开始于:Sun Feb 23 16:25:22 2020
子程序结束于:Sun Feb 23 16:25:26 2020
子程序开始于:Sun Feb 23 16:25:26 2020
子程序结束于:Sun Feb 23 16:25:28 2020
[主程序结束于:Sun Feb 23 16:25:28 2020

如果想让两次子程序并行运行,引入_thread模块:

"""
多线程示例
"""
import time
import _thread

def worker(n):
    print('子程序开始于:{}'.format(time.ctime()))
    time.sleep(n)
    print('子程序结束于:{}'.format(time.ctime()))

def main():
    print('[主程序开始于:{}'.format(time.ctime()))
    # 开始并行线程
    # 第一个参数是要运行的函数名,不加括号
    # 第二个参数是要运行的函数的参数,以元组的形式,如果只有一个参数,要加逗号
    _thread.start_new_thread(worker, (4,))
    _thread.start_new_thread(worker, (2,))
    print('[主程序结束于:{}'.format(time.ctime()))

if __name__ == '__main__':
    main()

输出:

[主程序开始于:Sun Feb 23 16:33:52 2020
[主程序结束于:Sun Feb 23 16:33:52 2020
子程序开始于:Sun Feb 23 16:33:52 2020

跟预想的不一样,因为_thread模块没有控制进程结束机制:

"""
多线程示例
"""
import time
import _thread

def worker(n):
    print('子程序开始于:{}'.format(time.ctime()))
    time.sleep(n)
    print('子程序结束于:{}'.format(time.ctime()))

def main():
    print('[主程序开始于:{}'.format(time.ctime()))
    # 开始并行线程
    # 第一个参数是要运行的函数名,不加括号
    # 第二个参数是要运行的函数的参数,以元组的形式,如果只有一个参数,要加逗号
    _thread.start_new_thread(worker, (4,))
    _thread.start_new_thread(worker, (2,))
    time.sleep(6)
    print('[主程序结束于:{}'.format(time.ctime()))

if __name__ == '__main__':
    main()

输出:

[主程序开始于:Sun Feb 23 16:37:21 2020
子程序开始于:Sun Feb 23 16:37:21 2020
子程序开始于:Sun Feb 23 16:37:21 2020
子程序结束于:Sun Feb 23 16:37:23 2020
子程序结束于:Sun Feb 23 16:37:25 2020
[主程序结束于:Sun Feb 23 16:37:27 2020

主程序执行的时间由time.sleep()里面的参数控制。

25_3.多线程之threading模块

使用threading模块改造上面的实例:

"""
threading模块示例
"""
import time
import threading

def worker(n):
    print('子程序开始于:{}'.format(time.ctime()))
    time.sleep(n)
    print('子程序结束于:{}'.format(time.ctime()))

def main():
    print('[主程序开始于:{}'.format(time.ctime()))
    # 开始并行线程
    # 第一个参数是要运行的函数名,不加括号
    # 第二个参数是要运行的函数的参数,以元组的形式,如果只有一个参数,要加逗号
    # _thread.start_new_thread(worker, (4,))
    # _thread.start_new_thread(worker, (2,))
    # time.sleep(6)

    threads = []
    t1 = threading.Thread(target=worker, args=(4,))
    threads.append(t1)
    t2 = threading.Thread(target=worker, args=(2,))
    threads.append(t2)

    for t in threads:
        t.start()

    print('[主程序结束于:{}'.format(time.ctime()))

if __name__ == '__main__':
    main()

输出:

[主程序开始于:Mon Feb 24 10:10:38 2020
子程序开始于:Mon Feb 24 10:10:38 2020
子程序开始于:Mon Feb 24 10:10:38 2020[主程序结束于:Mon Feb 24 10:10:38 2020

子程序结束于:Mon Feb 24 10:10:40 2020
子程序结束于:Mon Feb 24 10:10:42 2020

和预想的不一样。子程序还没结束主程序就已经结束了。可加入t.join():

"""
threading模块示例
""&
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值