Python多线程及其基本使用方法实例分析


Posted in Python onOctober 29, 2019

本文实例讲述了Python多线程及其基本使用方法。分享给大家供大家参考,具体如下:

学习Python的多线程(Multi-threading),至少应该要有进程与线程的基本概念,可以参考:http://www.ruanyifeng.com/blog/2013/04/processes_and_threads.html。

1.Python中的多线程

执行一个程序,即在操作系统中开启了一个进程,在某一时刻,一个CPU内核只能进行一个进程的任务,现在的计算机所说的多进程/多任务其实是通过加快CPU的执行速度来实现的,因为一个CPU每秒能执行上亿次的计算,能够对进程进行很多次切换,所以在人为可以感知的时间里,看上去,计算机确实是在同时执行多个程序,即同时处理多个进程。
一个进程中可以包含有多个线程,这多个线程为实现该进程的某个主要功能而运行着,多个线程可以进行串行工作,也可以并发同时进行工作,显然后者可以节省更多的时间。

在Python中是支持多线程并发执行的,只是Python中的多线程只能利用单核,也就是说Python中的某一个进程的多个线程只能在一个CPU核心上运行,而不能分配在多个CPU核心中运行,这是考虑到线程安全的缘故,而Python中的GIL则保证了线程安全。关于Python中的GIL,可以参考下面一篇文章:《浅析Python的GIL和线程安全》。

下面是自己在学习过程中的一些课堂笔记,因为还没有真正学习一些理论,所以可能会有些错误,但目前是方便自己的理解:

即GLI是以CPU核心为单位来控制全局锁,所以是不能跨不同的CPU(核心 )的GLI可以保证同一个进程中,某一个线程的共享数据在某一时刻只能同时被另外一个线程修改(使用),而不能同时被多个线程修改(使用),如果去掉GLI,则需要自己为线程加锁,这样之后,性能比原来还要差。

当然,难道就不能充分利用多核CPU或多个CPU了?

做成多进程就可以了,不同的进程运行在不同的CPU(核心)上,也可以实现并发,只是这样的话就会比较浪费内存空间,考虑同时运行10个QQ程序的情况,假如1个QQ占用500M的内存空间,则10个QQ就要占用5G的内存空间了。但如果是多线程的话,可能10个QQ还是共享着这500M的内存空间。还有一个缺点就是,多进程间的数据直接访问可能会比较麻烦,但其实也是可以实现的,比如chrome浏览器就是用多进程实现的。

目前首先要明确的是,Python中是不能把一个进程的多个线程分布在不同的CPU核心上运行的。

2.Python多线程使用方法1

给出下面的程序代码及注释:

import threading  #Python多线程模块
import time
def run(num):
  print 'Hi, I am thread %s..lalala' % num
  time.sleep(1)
for i in range(20):
  t = threading.Thread(target=run, args=(i,))  #多线程使用方法,target为需要执行多线程的函数,args为函数中的参数,注意这里的参数写成(i,),即如果只能一个参数,也要加上一个","
  t.start()  #开始执行多线程

程序运行结果如下:

xpleaf@xpleaf-machine:/mnt/hgfs/Python/day6$ python thread4.py
Hi, I am thread 0..lalala
Hi, I am thread 1..lalala
Hi, I am thread 2..lalala
Hi, I am thread 3..lalala
Hi, I am thread 4..lalala
Hi, I am thread 5..lalala
Hi, I am thread 6..lalala
Hi, I am thread 7..lalala
Hi, I am thread 8..lalala
Hi, I am thread 9..lalala
Hi, I am thread 10..lalala
Hi, I am thread 11..lalala
Hi, I am thread 12..lalala
Hi, I am thread 13..lalala
Hi, I am thread 14..lalala
Hi, I am thread 15..lalala
Hi, I am thread 16..lalala
Hi, I am thread 17..lalala
Hi, I am thread 18..lalala
Hi, I am thread 19..lalala

直接看执行结果是看不出什么的,这里说一下这个程序的执行过程:0到19是同时打印输入的,在打印19后,程序sleep 1秒后才结束程序的运行。

上面这个程序有20个线程执行,每个线程都是:打印字符串+sleep(1)。我们实际看到的结果是0到19同时打印,然后才sleep 1秒,但是需要注意的是,并非是20个线程才执行一次sleep(1),而是在每个线程中都执行了一次sleep(1),即该程序实际上是执行了20次sleep(1),而我们实际看到的结果是程序运行时仅仅是暂停了1秒,那是因为这20次sleep(1)是并发执行的。

上面的程序可以这么去理解:20个线程相当于有20匹马,20匹马同时起跑(打印字符串),然后以同时停1秒(sleep(1)),最后同时到达终点(20个线程运行结束,即程序执行结束)。

为了更好的理解上面的程序,可以把上面的代码改为如下:

import threading
import time
def run(num):
  print 'Hi, I am thread %s..lalala' % num
  time.sleep(1)
for i in range(20):
  t = threading.Thread(target=run, args=(i,))
  t.start()
  t.join()  #等上一个线程执行完后再执行下一个线程

执行结果如下:

xpleaf@xpleaf-machine:/mnt/hgfs/Python/day6$ python thread4.py
Hi, I am thread 0..lalala
Hi, I am thread 1..lalala
Hi, I am thread 2..lalala
Hi, I am thread 3..lalala
Hi, I am thread 4..lalala
Hi, I am thread 5..lalala
Hi, I am thread 6..lalala
Hi, I am thread 7..lalala
Hi, I am thread 8..lalala
Hi, I am thread 9..lalala
Hi, I am thread 10..lalala
Hi, I am thread 11..lalala
Hi, I am thread 12..lalala
Hi, I am thread 13..lalala
Hi, I am thread 14..lalala
Hi, I am thread 15..lalala
Hi, I am thread 16..lalala
Hi, I am thread 17..lalala
Hi, I am thread 18..lalala
Hi, I am thread 19..lalala

执行结果看上去跟前面是一样的,但执行过程却是这样的:每打印一次字符串,再暂停一秒。

通过这个程序,也就可以更好的理解Python的多线程并发执行了,当然,因为这是一个动态的过程,所以把程序执行一遍后会有更好的理解。

3.Python多线程使用方法2

程序代码如下:

import threading,time
class MyThread(threading.Thread):
  def __init__(self, num):
    threading.Thread.__init__(self)
    self.num = num
  def run(self): #this name must be 'run'
    print 'I am thread %s' % self.num
    time.sleep(2)
for i in range(20):
  t = MyThread(i)
  t.start()

程序的执行结果与方法1是一样的,这里就不给出了,只是这里利用了面向对象编程的思想方法来设计程序代码。

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
Python创建文件和追加文件内容实例
Oct 21 Python
python利用socketserver实现并发套接字功能
Jan 26 Python
python实现多层感知器
Jan 18 Python
python pandas写入excel文件的方法示例
Jun 25 Python
PyQt5+Caffe+Opencv搭建人脸识别登录界面
Aug 28 Python
python简单的三元一次方程求解实例
Apr 02 Python
python简单实现最大似然估计&scipy库的使用详解
Apr 15 Python
python 实现仿微信聊天时间格式化显示的代码
Apr 17 Python
基于python实现删除指定文件类型
Jul 21 Python
python读取excel数据并且画图的实现示例
Feb 08 Python
Python项目实战之使用Django框架实现支付宝付款功能
Feb 23 Python
解决Pytorch中关于model.eval的问题
May 22 Python
基于python的itchat库实现微信聊天机器人(推荐)
Oct 29 #Python
pygame实现非图片按钮效果
Oct 29 #Python
线程安全及Python中的GIL原理分析
Oct 29 #Python
pygame实现贪吃蛇游戏(下)
Oct 29 #Python
python TK库简单应用(实时显示子进程输出)
Oct 29 #Python
pygame实现贪吃蛇游戏(上)
Oct 29 #Python
利用Python小工具实现3秒钟将视频转换为音频
Oct 29 #Python
You might like
第十五节--Zend引擎的发展
2006/11/16 PHP
php下拉选项的批量操作的实现代码
2013/10/14 PHP
PHP加Nginx实现动态裁剪图片方案
2014/03/10 PHP
php.ini save_handler 修改不生效的解决办法
2014/07/22 PHP
getJSON跨域SyntaxError问题分析
2014/08/07 PHP
Linux+Nginx+MySQL下配置论坛程序Discuz的基本教程
2015/12/23 PHP
php微信开发自定义菜单
2016/08/27 PHP
PHP基于关联数组20行代码搞定约瑟夫问题示例
2017/11/07 PHP
laravel实现登录时监听事件,添加登录用户的记录方法
2019/09/30 PHP
浅析javascript闭包 实例分析
2010/12/25 Javascript
捕获浏览器关闭、刷新事件不同情况下的处理方法
2013/06/02 Javascript
跟我学习javascript的垃圾回收机制与内存管理
2015/11/23 Javascript
详解JavaScript的Date对象(制作简易钟表)
2020/04/07 Javascript
由浅入深讲解Javascript继承机制与simple-inheritance源码分析
2015/12/13 Javascript
使用Jasmine和Karma对AngularJS页面程序进行测试
2016/03/05 Javascript
微信小程序 用户数据解密详细介绍
2017/01/09 Javascript
详解JavaScript中this的指向问题
2017/01/20 Javascript
详解如何构建Angular项目目录结构
2017/07/13 Javascript
解决vue里碰到 $refs 的问题的方法
2017/07/13 Javascript
如何编写一个完整的Angular4 FormText 组件
2017/11/18 Javascript
Vue用v-for给循环标签自身属性添加属性值的方法
2018/10/18 Javascript
Python操作列表之List.insert()方法的使用
2015/05/20 Python
pytorch之inception_v3的实现案例
2020/01/06 Python
浅谈keras中自定义二分类任务评价指标metrics的方法以及代码
2020/06/11 Python
python爬虫筛选工作实例讲解
2020/11/23 Python
Sandro法国官网:法国成衣品牌
2019/08/28 全球购物
奥地利时尚、美容、玩具和家居之家:Kastner & Öhler
2020/04/26 全球购物
大学校运会广播稿
2014/02/03 职场文书
《青蛙看海》教学反思
2014/04/23 职场文书
竞选大队长演讲稿
2014/04/29 职场文书
大型活动组织方案
2014/05/10 职场文书
我的梦想演讲稿1000字
2014/08/21 职场文书
关于教师节的广播稿
2014/09/10 职场文书
竞选大队干部演讲稿
2014/09/11 职场文书
2015年实习单位评语
2015/03/25 职场文书
vue基于Teleport实现Modal组件
2021/05/31 Vue.js