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 ...
随机推荐
- win10一行代码搭建本地html项目
最近玩了下web项目,需要部署到本地查看效果. 一:准备 1.安装python或者安装node.js 2.html项目文件 二:python搭建 1.进入html文件的路径 2.通过python命令部 ...
- Win10访问Ubuntu的samba共享文件
大致分为以下几个步骤: 一.开启samba服务器 二.配置共享目录和用户权限 三.开启samba客户端 四.访问共享目录 一:开启samba服务器 安装samba服务器: sudo apt-get ...
- Kafka入门之broker-消息设计
消息设计 1.消息格式 Kafka的实现方式本质上是使用java NIO的ByteBuffer来保存消息,同时依赖文件系统提供的页缓存机制,而非依靠java的堆缓存. 2.版本变迁 0.11.0.0版 ...
- NameServer路由删除
NameServer会每隔10s扫描brokerLiveTable状态表,如果BrokerLive的lastUpdateTimestamp的时间戳距当前时间超过120s,则认为Broker失效,移除改 ...
- 腾讯云linux系统部署项目无法通过外网访问
最近尝试使用了一下腾讯去的linux系统服务器,但是却遇到各种问题,下面记录的问题是项目部署完成后却无法通过外网访问. 服务器:腾讯云 系统 :CentOS 8.0 64位 处理思路:通过度娘百般摸索 ...
- markdown详细
在写博客时,想设置字体 颜色参照[(https://blog.csdn.net/wo919191/article/details/84249531)] 图片参照 背景色: gray
- 【NOIP2017提高A组模拟9.17】组合数问题
[NOIP2017提高A组模拟9.17]组合数问题 题目 Description 定义"组合数"S(n,m)代表将n 个不同的元素拆分成m 个非空集合的方案数. 举个例子,将{1,2,3}拆分成2 个 ...
- Spring Cloud 学习 (八) Spring Boot Admin
Spring Boot Admin 用于管理和监控一个或者多个 Spring Boot 程序 新建 spring-boot-admin-server pom <parent> <ar ...
- 20200203_windows2012下安装mysql 5.7.29
一. 检查系统版本: 二. 下载mysql, 下载地址: https://dev.mysql.com/downloads/mysql/5.7.html#downloads 三. 解压下载后的压 ...
- go结构体与方法
go结构体相当于python中类的概念 结构体用来定义复杂的数据结构,存储很多相同的字段属性 1.结构体的定义以及简单实用 package main import ( "fmt" ...