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 ...
随机推荐
- Elasticsearch 理解mapping中的store属性
默认情况下,对字段值进行索引以使其可搜索,但不存储它们 (store). 这意味着可以查询该字段,但是无法检索原始字段值.在这里我们必须理解的一点是: 如果一个字段的mapping中含有store属性 ...
- 安装git和lsof
yum install git yum install lsof 查看80端口 lsof -i:80
- 2016年第七届蓝桥杯【C++省赛B组】F、G、H、J 题解
F. 方格填数 #深搜 题意 有\(10\)个格子,填入0~9的数字.要求:连续的两个数字不能相邻.(左右.上下.对角都算相邻),求可能的填数方案数. +--+--+--+ | | | | +--+- ...
- Java基础教程——模拟B/S结构的服务器
浏览器发送请求,用Java模拟写个简单的服务器,浏览器可以收到响应. 执行下列代码(设置static final int TEST = 1), 使用浏览器访问:http://127.0.0.1:888 ...
- 那么多人学习C++,学习它有什么好处?学完以后能从事哪些岗位?
相信很多人接触编程都是源于大学期间的那堂C++语言程序编程,但是这门课却只告诉了你编程语言是什么,却没告诉你要怎么去熟练掌握编程.所以,不可避免的是许多人在毕业前夕才发现虽然学会了C++,但是好像却不 ...
- 团队作业第三次 —— UML设计
这个作业要求在哪里 https://edu.cnblogs.com/campus/fzzcxy/2018SE2/homework/11366 这个作业的目标 <团队一起设计UML图> 团队 ...
- 03Python网络编程之单线程服务端
# 对于单线程的服务端,我们借助于zen_utils(我们自己编写好的一些函数)是很容易就实现的.# 导入这个模块import zen_utilsif __name__ == '__main__': ...
- 【五校联考1day2】JZOJ2020年8月12日提高组T1 对你的爱深不见底
[五校联考1day2]JZOJ2020年8月12日提高组T1 对你的爱深不见底 题目 Description 出乎意料的是,幸运E 的小R 居然赢了那个游戏.现在欣喜万分的小R 想要写一张明信片给小Y ...
- Django搭建示例项目实战与避坑细节
Django 开发项目是很快的,有多快?看完本篇文章,你就知道了. 安装 Django 前提条件:已安装 Python. Django 使用 pip 命令直接就可以安装: pip install dj ...
- 喜欢 Dapper 的朋友看过来,送一份厚礼
写在开头 众所周知 Dapper 是 .NET 下最轻最快的 ORM,它是喜欢写 SQL 码农的福音,相对于 SqlHelper 它更加方便,据统计 10个 .NETer 有 9个 用过 Dapper ...