Python多线程thread及模块使用实例


Posted in Python onApril 28, 2020

多线程类似于同时执行多个不同程序,多线程运行有如下优点:

  • 使用线程可以把占据长时间的程序中的任务放到后台去处理。
  • 用户界面可以更加吸引人,这样比如用户点击了一个按钮去触发某些事件的处理,可以弹出一个进度条来显示处理的进度
  • 程序的运行速度可能加快
  • 在一些等待的任务实现上如用户输入、文件读写和网络收发数据等,线程就比较有用了。在这种情况下我们可以释放一些珍贵的资源如内存占用等等。

线程在执行过程中与进程还是有区别的。每个独立的线程有一个程序运行的入口、顺序执行序列和程序的出口。但是线程不能够独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。

每个线程都有他自己的一组CPU寄存器,称为线程的上下文,该上下文反映了线程上次运行该线程的CPU寄存器的状态。

指令指针和堆栈指针寄存器是线程上下文中两个最重要的寄存器,线程总是在进程得到上下文中运行的,这些地址都用于标志拥有线程的进程地址空间中的内存。

线程可以被抢占(中断)。

在其他线程正在运行时,线程可以暂时搁置(也称为睡眠) -- 这就是线程的退让。

线程可以分为:

内核线程:由操作系统内核创建和撤销。

用户线程:不需要内核支持而在用户程序中实现的线程。

Python3 线程中常用的两个模块为:

  • _thread
  • threading(推荐使用)

thread 模块已被废弃。用户可以使用 threading 模块代替。所以,在 Python3 中不能再使用"thread" 模块。为了兼容性,Python3

将 thread 重命名为 "_thread"。

Python中使用线程有两种方式:函数或者用类来包装线程对象。

函数式:调用 _thread 模块中的start_new_thread()函数来产生新线程。语法如下:

_thread.start_new_thread ( function, args[, kwargs] )

参数说明:

  • function - 线程函数。
  • args - 传递给线程函数的参数,他必须是个tuple类型。
  • kwargs - 可选参数。
import _thread
from time import sleep
import datetime

def date_time_str():
  return datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S')
def loop_one():
  print('++++线程一开始于:',date_time_str())
  print('++++线程一休眠4秒')
  sleep(4)
  print('++++线程一休眠结束,结束于:',date_time_str())
      
def loop_two():
  print('++++线程二开始于:',date_time_str())
  print('++++线程二休眠2秒')
  sleep(2)
  print('++++线程二休眠结束,结束于:',date_time_str())
      
def main():
  print('-----所有线程开始时间:',date_time_str())
  _thread.start_new_thread(loop_one,())
  _thread.start_new_thread(loop_two,())
  sleep(6)
  print('------所有线程结束时间:',date_time_str())
      
if __name__=='__main__':
  main()

运行结果:

[python@master thread]$ python3 thread.py
-----所有线程开始时间: 2018-11-08 19:07:54
++++线程一开始于: 2018-11-08 19:07:54
++++线程一休眠4秒
++++线程二开始于: 2018-11-08 19:07:54
++++线程二休眠2秒
++++线程二休眠结束,结束于: 2018-11-08 19:07:56
++++线程一休眠结束,结束于: 2018-11-08 19:07:58
------所有线程结束时间: 2018-11-08 19:08:00

sleep(6) 是让主线程停下来,主线程一旦运行结束,就关闭运行着的其他两个线程,这可能造成主线程过早或者过晚退出,这时就要用线程锁,主线程可认在两个子进程都退出后立即退出。代码如下:

import _thread
from time import sleep
import datetime

loops=[4,2]

def date_time_str():
  return datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S')
def loop(n_loop,n_sec,lock):
  print('线程(',n_loop,') 开始执行:',date_time_str(),',先休眠(',n_sec,')秒')
  sleep(n_sec)
  print('线程(',n_loop,')休眠结束,结束于:',date_time_str())
  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())
  
if __name__=='__main__':
  main()

运行结果:

[python@master thread]$ python3 thread2.py
---所有线程开始执行...
线程( 1 ) 开始执行: 2018-11-08 20:00:47 ,先休眠( 2 )秒
线程( 0 ) 开始执行: 2018-11-08 20:00:47 ,先休眠( 4 )秒
线程( 1 )休眠结束,结束于: 2018-11-08 20:00:49
线程( 0 )休眠结束,结束于: 2018-11-08 20:00:51
---所有线程执行结束: 2018-11-08 20:00:51

使用了线程锁。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python使用django获取用户IP地址的方法
May 11 Python
Python从MP3文件获取id3的方法
Jun 15 Python
浅析python中SQLAlchemy排序的一个坑
Feb 24 Python
Python入门_浅谈逻辑判断与运算符
May 16 Python
Python查询IP地址归属完整代码
Jun 21 Python
详解Python实现多进程异步事件驱动引擎
Aug 25 Python
Python基于回溯法子集树模板解决0-1背包问题实例
Sep 02 Python
Python3 实现减少可调用对象的参数个数
Dec 20 Python
python怎么判断模块安装完成
Jun 19 Python
详细分析Python垃圾回收机制
Jul 01 Python
selenium学习教程之定位以及切换frame(iframe)
Jan 04 Python
python lambda的使用详解
Feb 26 Python
Python基于模块Paramiko实现SSHv2协议
Apr 28 #Python
Python内置函数locals和globals对比
Apr 28 #Python
使用python实现CGI环境搭建过程解析
Apr 28 #Python
基于python连接oracle导并出数据文件
Apr 28 #Python
numpy库ndarray多维数组的维度变换方法(reshape、resize、swapaxes、flatten)
Apr 28 #Python
简单了解python shutil模块原理及使用方法
Apr 28 #Python
python脚本监控logstash进程并邮件告警实例
Apr 28 #Python
You might like
PHP 高手之路(三)
2006/10/09 PHP
php 数组排序 array_multisort与uasort的区别
2011/03/24 PHP
PHP基础之运算符的使用方法
2013/04/28 PHP
护卫神php套件 php版本升级方法(php5.5.24)
2015/05/10 PHP
基于PHP实现用户在线状态检测
2020/11/10 PHP
jQuery 源码分析笔记(5) jQuery.support
2011/06/19 Javascript
js解析与序列化json数据(一)json.stringify()的基本用法
2013/02/01 Javascript
jquery拖动插件(jquery.drag)使用介绍
2013/06/18 Javascript
jQuery中append()方法用法实例
2015/01/08 Javascript
使用js画图之饼图
2015/01/12 Javascript
使用JQuery 加载页面时调用JS的实现方法
2016/05/30 Javascript
javascript实现消灭星星小游戏简单版
2016/11/15 Javascript
Node.js与Sails redis组件的使用教程
2017/02/14 Javascript
JS将unicode码转中文方法
2017/05/08 Javascript
js获取元素的偏移量offset简单方法(必看)
2017/07/05 Javascript
通过一个简单的例子学会vuex与模块化
2017/11/22 Javascript
解决easyui日期时间框ie的兼容的问题
2018/03/01 Javascript
《javascript少儿编程》location术语总结
2018/05/27 Javascript
vuex actions传递多参数的处理方法
2018/09/18 Javascript
微信小程序自定义toast的实现代码
2018/11/16 Javascript
深入学习Vue nextTick的用法及原理
2019/10/08 Javascript
原生js实现九宫格拖拽换位
2021/01/26 Javascript
[01:32]DOTA2上海特锦赛现场采访:最想COS的英雄
2016/03/25 DOTA
pytorch 调整某一维度数据顺序的方法
2018/12/08 Python
Python实现的栈、队列、文件目录遍历操作示例
2019/05/06 Python
Python input函数使用实例解析
2019/11/22 Python
python如何通过pyqt5实现进度条
2020/01/20 Python
Python flask框架实现查询数据库并显示数据
2020/06/04 Python
python中的插入排序的简单用法
2021/01/19 Python
类成员函数的重载、覆盖和隐藏区别
2016/01/27 面试题
Java面试题:为什么要用Java
2012/05/11 面试题
教师一岗双责责任书
2014/04/16 职场文书
公司任命书模板
2014/06/06 职场文书
环境科学专业教师求职信
2014/07/12 职场文书
预备党员个人总结
2015/02/14 职场文书
22句经典语录:送给优柔寡断和胡思乱想的朋友们
2019/12/13 职场文书