当前位置:   article > 正文

python之多线程并发

python之多线程并发

前言

今天呢笔者想和大家来聊聊python多线程的并发,废话就不多说了咱们直接进入主题哟。

 

一、线程执行

python的内置模块提供了两个内置模块:thread和threading,thread是源生模块,threading是扩展模块,在thread的基础上进行了封装及改进。所以只需要使用threading这个模块就能完成并发的测试

实例

创建并启动一个单线程

  1. import threading
  2. def myTestFunc():
  3. print("我是一个函数")
  4. t = threading.Thread(target=myTestFunc) # 创建一个线程
  5. t.start() # 启动线程

执行结果

  1. C:\Python36\python.exe D:/MyThreading/myThread.py
  2. 我是一个线程函数
  3. Process finished with exit code 0

其实单线程的执行结果和单独执行某一个或者某一组函数结果是一样的,区别只在于用线程的方式执行函数,而线程是可以同时执行多个的,函数是不可以同时执行的。

二、多线程执行

上面介绍了单线程如何使用,多线程只需要通过循环创建多个线程,并循环启动线程执行就可以了

实例

  1. import threading
  2. from datetime import datetime
  3. def thread_func(): # 线程函数
  4. print('我是一个线程函数', datetime.now())
  5. def many_thread():
  6. threads = []
  7. for _ in range(10): # 循环创建10个线程
  8. t = threading.Thread(target=thread_func)
  9. threads.append(t)
  10. for t in threads: # 循环启动10个线程
  11. t.start()
  12. if __name__ == '__main__':
  13. many_thread()

执行结果

  1. C:\Python36\python.exe D:/MyThreading/manythread.py
  2. 我是一个线程函数 2022-06-23 16:54:58.205146
  3. 我是一个线程函数 2022-06-23 16:54:58.205146
  4. 我是一个线程函数 2022-06-23 16:54:58.206159
  5. 我是一个线程函数 2022-06-23 16:54:58.206159
  6. 我是一个线程函数 2022-06-23 16:54:58.206159
  7. 我是一个线程函数 2022-06-23 16:54:58.207139
  8. 我是一个线程函数 2022-06-23 16:54:58.207139
  9. 我是一个线程函数 2022-06-23 16:54:58.207139
  10. 我是一个线程函数 2022-06-23 16:54:58.208150
  11. 我是一个线程函数 2022-06-23 16:54:58.208150
  12. Process finished with exit code 0

通过循环创建10个线程,并且执行了10次线程函数,但需要注意的是python的并发并非绝对意义上的同时处理,因为启动线程是通过循环启动的,还是有先后顺序的,通过执行结果的时间可以看出还是有细微的差异,但可以忽略不记。当然如果线程过多就会扩大这种差异。我们启动500个线程看下程序执行时间

实例

  1. import threading
  2. from datetime import datetime
  3. def thread_func(): # 线程函数
  4. print('我是一个线程函数', datetime.now())
  5. def many_thread():
  6. threads = []
  7. for _ in rang
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Cpp五条/article/detail/181307?site
推荐阅读
相关标签
  

闽ICP备14008679号