python并发编程——多线程
编程的乐趣在于让程序越来越快,这里将给大家介绍一个种加快程序运行的的编程方式——多线程
1 著名的全局解释锁(GIL)
- #!/usr/bin/env python
- # -*- coding: utf-8 -*-
- """
- Created on Mon Jun 5 16:12:14 2017
- @author: 80002419
- """
- import threading
- import time
- def cost(fun):##定义一个装饰器,用来计算函数运行的时间
- def wrapper(*args,**kargs):
- before_tm = time.time()
- fun(*args,**kargs);
- after_tm = time.time()
- fun.__doc__
- print("{0} cost:{1}".format(fun.__name__,after_tm-before_tm))
- return wrapper
- def fibs1(n):
- if (n == 1):
- return 0
- elif(n == 2):
- return 1
- else:
- return fibs1(n-2)+fibs1(n-1)
- def fibs2(n):
- list = []
- if (n == 1):
- list = [0]
- return list[-1]
- elif(n == 2):
- list = [0,1]
- return list[-1]
- else:
- list = [0,1]
- for i in range(2,n):
- list.append(list[i-1]+list[i-2])
- return list[-1]
- @cost
- def nothread():
- fibs1(35)
- fibs1(35)
- #@cost
- #def nothread1():
- # print(fibs2(40))
- # print(fibs2(40))
- @cost
- #使用多线程的程序
- def inthread():
- threads = []
- for i in range(2):
- t = threading.Thread(target = fibs1,args =(35,))
- t.start()
- threads.append(t)
- for t in threads:
- t.join()
- @cost
- def inthread1():
- for i in range(2):
- t = threading.Thread(target=fibs1, args=(35,))
- t.start()
- main_thread = threading.currentThread()
- for t in threading.enumerate():
- if t is main_thread:
- continue
- t.join()
- nothread()
- inthread()
打印结果:
inthread cost:14.6728241444
对于cpu密集型任务,使用多线程反而会减慢程序的运行。
GIL是必须的,这是Python设计的问题:Python解释器是非线程安全的。这意味着当从线程内尝试安全的访问Python对象的时候将有一个全局的强制锁。当然python
多线程也有可以加快程序运行的时候:当我们开发和网络通信或者数据输入/输出相关的程序,比如网络爬虫、文本处理等等。这时候由于网络情况和I/O的性能的限制,Python解释器会等待读写数据的函数调用返回,这个时候就可以利用多线程库提高并发效率了。这类任务我们称为IO(密集型任务)
2 Semaphore类 ——python对象访问量的控制
- #!/usr/bin/env python
- # -*- coding: utf-8 -*-
- """
- Created on Mon Jun 5 16:12:14 2017
- @author: 80002419
- """
- from threading import Thread, Semaphore
- import time,threading
- sema = Semaphore(3) # 定义一个信号量为3的Semaphone对象,
- #定义一个测试函数作为,被访问的对象
- def test(tid):
- with sema:
- print("信号量:{0}".format(tid))
- time.sleep(0.5)
- print('release!')
- thds = []
- for i in range(6):
- t = Thread(target = test,args=(i,))
- t.start()
- thds.append(t)
- for t in thds:
- t.join()
打印结果:
信号量:1
信号量:0
release!
信号量:0
release!
信号量:0
release!
信号量:0
release!
release!
release!
Semaphore类的作用就是限制公共资源的访问量
- #!/usr/bin/env python
- # -*- coding: utf-8 -*-
- """
- Created on Mon Jun 5 16:12:14 2017
- @author: 80002419
- """
- from threading import Thread, Lock
- import time,threading
- value = 0;
- def changeValue():
- global value
- new = value + 1
- time.sleep(0.001)#让其它进程可以切换进来
- value = new
- thds = []
- for _ in range(100):
- t = Thread(target = changeValue)
- t.start()
- thds.append(t)
- for t in thds:
- t.join()
- print(value)
打印结果:
- #!/usr/bin/env python
- # -*- coding: utf-8 -*-
- """
- Created on Mon Jun 5 16:12:14 2017
- @author: 80002419
- """
- from threading import Thread, Lock
- import time,threading
- value = 0
- lock = Lock()
- def changeValue():
- global value
- with lock:
- new = value + 1
- time.sleep(0.001)#让其它进程可以切换进来
- value = new
- thds = []
- for _ in range(100):
- t = Thread(target = changeValue)
- t.start()
- thds.append(t)
- for t in thds:
- t.join()
- print(value)
打印结果:
想要获取更多Python学习资料可以加
QQ:2955637827私聊
或加Q群630390733
大家一起来学习讨论吧!
python并发编程——多线程的更多相关文章
- python并发编程&多线程(二)
前导理论知识见:python并发编程&多线程(一) 一 threading模块介绍 multiprocess模块的完全模仿了threading模块的接口,二者在使用层面,有很大的相似性 官网链 ...
- python并发编程&多线程(一)
本篇理论居多,实际操作见: python并发编程&多线程(二) 一 什么是线程 在传统操作系统中,每个进程有一个地址空间,而且默认就有一个控制线程 线程顾名思义,就是一条流水线工作的过程,一 ...
- python 并发编程 多线程 目录
线程理论 python 并发编程 多线程 开启线程的两种方式 python 并发编程 多线程与多进程的区别 python 并发编程 多线程 Thread对象的其他属性或方法 python 并发编程 多 ...
- Python并发编程——多线程与协程
Pythpn并发编程--多线程与协程 目录 Pythpn并发编程--多线程与协程 1. 进程与线程 1.1 概念上 1.2 多进程与多线程--同时执行多个任务 2. 并发和并行 3. Python多线 ...
- python并发编程-多线程实现服务端并发-GIL全局解释器锁-验证python多线程是否有用-死锁-递归锁-信号量-Event事件-线程结合队列-03
目录 结合多线程实现服务端并发(不用socketserver模块) 服务端代码 客户端代码 CIL全局解释器锁****** 可能被问到的两个判断 与普通互斥锁的区别 验证python的多线程是否有用需 ...
- python 并发编程 多线程 GIL与多线程
GIL与多线程 有了GIL的存在,同一时刻同一进程中只有一个线程被执行 多进程可以利用多核,但是开销大,而python的多线程开销小,但却无法利用多核优势 1.cpu到底是用来做计算的,还是用来做I/ ...
- python 并发编程 多线程 GIL全局解释器锁基本概念
首先需要明确的一点是GIL并不是Python的特性,它是在实现Python解析器(CPython)时所引入的一个概念. 就好比C++是一套语言(语法)标准,但是可以用不同的编译器来编译成可执行代码. ...
- python 并发编程 多线程 GIL与Lock
GIL与Lock Python已经有一个GIL来保证同一时间只能有一个线程来执行了,为什么这里还需要互斥锁lock? 锁的目的是为了保护共享的数据,同一时间只能有一个线程来修改共享的数据 GIT保证了 ...
- python 并发编程 多线程 线程queue
线程queue 线程之间已经是共享数据的,为什么还使用线程queue? 线程需要自己加锁,线程queue帮我们处理好加锁的问题 有三种不同的用法 第一种方法: class queue.Queue(ma ...
随机推荐
- VMW14.x虚拟机安装Mac10.13系统教程
之前虚拟机安装Mac经常出问题,所以这次又重新安装Mac,为了加深映像和之后回忆方便,特写下此次安装教程. 一 工具的准备: 首先准备教程的软件和包 1,虚拟机VMW 下载地址:https:// ...
- Problem D. Country Meow 题解(三分套三分套三分)
题目链接 题目大意 给你n(n<=100)个点,要你找一个点使得和所有点距离的最大值最小值ans 题目思路 一直在想二分答案,但是不会check 这个时候就要换一下思想 三分套三分套三分坐标即可 ...
- SpringBoot整合Elasticsearch7
SpringBoot连接ElasticSearch有以下种方式, TransportClient,9300端口,在 7.x 中已经被弃用,据说在8.x 中将完全删除 restClient,9200端口 ...
- dubbo协议之响应头编码器&响应对象编码
前2节分析完了请求头和请求对象的编码,这里看一下响应头和响应对象的编码: 和请求头部一样进来先指定序列化器,没有的话用默认的Hessian2,接下来2个字节的操作和请求头编码类似,第三个字节时去req ...
- CentOS SSH安全和配置无密码登录
CentOS ssh默认监听端口 22端口,允许root用户ssh登录.server投入生产后很有必要更改默认ssh监听端口和禁止root登录. 步骤1:确认安装有ssh包 [appuser@su17 ...
- docker安装myInfluxDB映射本地目录+开机后台自启动
CentOS7环境 1.docker hup库搜索influxdb docker search influxdb 2.拉取influxdb镜像 docker pull influxdb 3.查看已下载 ...
- Spring Boot + Sharding-JDBC 读写分离
本文使用 Sharding-JDBC 实现读写分离,基于 CentOS 7 + MySQL 5.7 一.MySQL 安装及配置 1.1 安装 依次执行命令: sudo wget -i -c http: ...
- 网络编程原理与UDP实现
如何发送数据包? Q:当应用程序产生数据的时候,需要去构造数据包并发送到网络上去,但是由谁负责处理呢? A:现代操作系统负责数据包得构造与发送,应用程序只需提供数据. 当应用程序产生数据时,应用程序将 ...
- PyQt(Python+Qt)学习随笔:QStandardItemModel指定行和列创建模型后的数据项初始化的两种方法
老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 QStandardItemModel通过构造方法 QStandardItemModel(int ro ...
- 第十五章 使用PyQt进行Python图形界面程序开发
在基础知识部分的最后一章<第十三章 Python基础篇结束章>的<第13.3节 图形界面开发tkinter>简单介绍了Python内置图形界面标准库tkinter,当时特别强调 ...