基于线程的并行-Python 并行编程学习笔记(一)
前言
最近写一些模拟集群智能的算法,虽然机制简单,但是随着个体的增加,设计的计算量就比较大了,尤其是加上matplotlib进行动态展示,使得运算量骤增,看着画面也比较卡.之前想把算法转化成c++代码,利用qt进行展示,入了坑才发现不是一朝一夕之功,没办法,还是回到自己熟悉的python上看看能不能优化一下代码.然后买了<<Python 并行编程-第二版>>这本书从头学起,希望用两三个月把这个整个七七八八.我相信我能坚持下去,把这块骨头啃明白.算是一个学习笔记吧,加上一些自己的理解,如果有哪位看官看到此文,发现讲到不对的地方加以批评指正.
基于线程的并行
threading模块提供的Thread类
class threading.Thread(group=None, target=None, name=None, args=(), kwargs={})
主要的参数就三个:
- target:线程要执行的目标函数
- name:线程名
- args:目标函数的参数
下面是一个简单的例子:
import threading
import time
import random
def sleep_out(i):
print("{}号程序开始执行\n".format(i))
num = random.randint(0, 10)
time.sleep(num)
print("{}号程序休息了{}s\n".format(i,num))
if __name__ == "__main__":
threads = []
for i in range(10):
t = threading.Thread(target=sleep_out, args=(i,), name="thread-{}".format(i))
threads.append(t)
for t in threads:
t.start()
for t in threads:
t.join()
-----------------------------------输出-----------------------------
0号程序开始执行
1号程序开始执行
2号程序开始执行
3号程序开始执行
4号程序开始执行
5号程序开始执行
6号程序开始执行
7号程序开始执行
8号程序开始执行
9号程序开始执行
8号程序休息了1s
7号程序休息了4s
6号程序休息了5s
2号程序休息了6s
4号程序休息了7s
0号程序休息了7s
3号程序休息了8s
1号程序休息了10s
9号程序休息了10s
5号程序休息了10s
进程已结束,退出代码0
线程开始执行使用start()方法,一旦线程开始执行,则运行会转入后台,主线程继续执行.而要等待一个线程结束,必须使用join()方法,该方法会让主线程进入等待状态,直到线程执行完毕,主线程才会继续执行.
我们将刚才的程序改写为:
import threading
import time
import random
def sleep_out(i):
print("{}号程序开始执行\n".format(i))
num = random.randint(0, 10)
time.sleep(num)
print("{}号程序休息了{}s\n".format(i,num))
if __name__ == "__main__":
threads = []
for i in range(10):
t = threading.Thread(target=sleep_out, args=(i,), name="thread-{}".format(i))
threads.append(t)
t.start()
t.join()
-----------------------------------输出-----------------------------
0号程序开始执行
0号程序休息了6s
1号程序开始执行
1号程序休息了6s
2号程序开始执行
2号程序休息了8s
3号程序开始执行
3号程序休息了0s
4号程序开始执行
4号程序休息了5s
5号程序开始执行
5号程序休息了1s
6号程序开始执行
6号程序休息了8s
7号程序开始执行
7号程序休息了8s
8号程序开始执行
8号程序休息了10s
9号程序开始执行
9号程序休息了9s
进程已结束,退出代码0
start()方法和join()方法相辅相成,一般不能独立存在.
确定当前线程
使用currentThread().getName()方法会返回当前线程名.
继续在刚才的代码上修改:
import threading
import time
import random
def sleep_out(i):
print("{}号程序开始执行\n".format(i))
print("当前线程为"+threading.currentThread().getName())
num = random.randint(0, 10)
time.sleep(num)
print("{}号程序休息了{}s\n".format(i,num))
if __name__ == "__main__":
threads = []
for i in range(10):
t = threading.Thread(target=sleep_out, args=(i,), name="thread-{}".format(i))
threads.append(t)
t.start()
t.join()
-----------------------------------输出-----------------------------
0号程序开始执行
当前线程为thread-0
0号程序休息了2s
1号程序开始执行
当前线程为thread-1
1号程序休息了2s
2号程序开始执行
当前线程为thread-2
2号程序休息了3s
3号程序开始执行
当前线程为thread-3
3号程序休息了1s
4号程序开始执行
当前线程为thread-4
4号程序休息了3s
5号程序开始执行
当前线程为thread-5
5号程序休息了1s
6号程序开始执行
当前线程为thread-6
6号程序休息了2s
7号程序开始执行
当前线程为thread-7
7号程序休息了1s
8号程序开始执行
当前线程为thread-8
8号程序休息了1s
9号程序开始执行
当前线程为thread-9
9号程序休息了4s
进程已结束,退出代码0
自定义线程类
我们可以创建继承Thread类的子类,再重新定义run()方法,实现自己需要的功能.
示例如下:
import time
import threading
from random import randint
import os
def sleep_out(num):
time.sleep(num)
class MyThreadClass(threading.Thread):
def __init__(self, name, duration):
threading.Thread.__init__(self)
self.name = name
self.duration = duration
def run(self):
print("线程:" + self.name + "正在运行, 进程ID:" + str(os.getpid()))
sleep_out(self.duration)
print("线程" + self.name + "结束!!!")
if __name__ == "__main__":
start_time = time.time()
threads = []
for i in range(10):
t = MyThreadClass(name="thread-{}".format(i), duration=randint(0, 5))
threads.append(t)
for t in threads:
t.start()
for t in threads:
t.join()
print("-----{}-----".format(time.time() - start_time))
----------输出----------
线程:thread-0正在运行, 进程ID:11804
线程thread-0结束!!!
线程:thread-1正在运行, 进程ID:11804
线程:thread-2正在运行, 进程ID:11804
线程:thread-3正在运行, 进程ID:11804
线程:thread-4正在运行, 进程ID:11804
线程:thread-5正在运行, 进程ID:11804
线程:thread-6正在运行, 进程ID:11804
线程:thread-7正在运行, 进程ID:11804
线程:thread-8正在运行, 进程ID:11804
线程:thread-9正在运行, 进程ID:11804
线程thread-6结束!!!线程thread-8结束!!!
线程thread-5结束!!!
线程thread-7结束!!!
线程thread-9结束!!!
线程thread-2结束!!!线程thread-3结束!!!
线程thread-1结束!!!线程thread-4结束!!!
-----5.019770860671997-----
基于线程的并行-Python 并行编程学习笔记(一)的更多相关文章
- python 函数式编程学习笔记
函数基础 一个函数就是将一些语句集合在一起的部件,它们能够不止一次地在程序中运行.函数的主要作用: 最大化的代码重用和最小化代码冗余 流程的分解 一般地,函数讲的流程是:告诉你怎样去做某事,而不是让你 ...
- Python核心编程--学习笔记--1--Python简介
本章介绍了Python的背景知识,包括什么是Python.Python的起源以及Python的一些关键特性. 1 什么是Python Python是一门优雅而健壮的编程语言,它继承了传统编译语言的强大 ...
- python网络编程学习笔记(三):socket网络服务器(转载)
1.TCP连接的建立方法 客户端在建立一个TCP连接时一般需要两步,而服务器的这个过程需要四步,具体见下面的比较. 步骤 TCP客户端 TCP服务器 第一步 建立socket对象 建立socket对 ...
- Python核心编程--学习笔记--4--Python对象
现在开始学习Python语言的核心部分.首先了解什么是Python对象,然后讨论最常用的内建类型,接下来讨论标准类型运算符和内建函数,之后给出对标准类型的不同分类方式,最后提一提Python目前还不支 ...
- Python核心编程--学习笔记--3--Python基础
本章介绍基本的Python语法.编程风格:并简要介绍标识符.变量和关键字,以及变量占用内存的分配和回收:最后给出一个较大的Python样例程序来体验这些特性. 1 语句和语法 1.1 注释 可以在一行 ...
- python网络编程学习笔记(10):webpy框架
转载请注明:@小五义http://www.cnblogs.com/xiaowuyi django和webpy都是python的web开发框架.Django的主要目的是简便.快速的开发数据库驱动的网站. ...
- python多进程编程学习笔记
摘自[https://www.cnblogs.com/chenhuabin/p/10070996.html] by 奥辰 赞
- Python核心编程--学习笔记--9--文件和输入输出
本章将深入介绍Python的文件处理和相关输入输出能力,包括:文件对象(以及它的内建函数.内建方法和属性),标准文件,文件系统的访问方法,文件执行,最后简要涉及持久存储和标准库中与文件有关的模块. 1 ...
- Python核心编程--学习笔记--8--条件与循环
本章讲述if.while.for以及与他们搭配的else.elif.break.continue.pass等语句. 1 if语句 语法:三部分——关键字if.条件表达式.代码块.(记住冒号) if c ...
- Python核心编程--学习笔记--7--字典和集合
本章介绍Python语言中的映射类型(字典)和集合类型,包括操作符.工厂函数.内建函数与方法. 1 字典 字典是Python中唯一的映射类型——键key直接映射到值value.字典是容器类型,其对象是 ...
随机推荐
- ARL灯塔系统搭建
前言 ARL(Asset Reconnaissance Lighthouse)资产侦查灯塔,是一个良好的资产收集系统,旨在为渗透测试人员以及安全团队基于企业的网络安全能快速查找到指定企业资产中的脆弱点 ...
- 90%的Java开发人员都会犯的5个错误
前言 作为一名java开发程序员,不知道大家有没有遇到过一些匪夷所思的bug.这些错误通常需要您几个小时才能解决.当你找到它们的时候,你可能会默默地骂自己是个傻瓜.是的,这些可笑的bug基本上都是你忽 ...
- [编程基础] C++多线程入门8-从线程返回值
原始C++标准仅支持单线程编程.新的C++标准(称为C++11或C++0x)于2011年发布.在C++11中,引入了新的线程库.因此运行本文程序需要C++至少符合C++11标准. 8 从线程返回值 8 ...
- [编程基础] C++多线程入门6-事件处理的需求
原始C++标准仅支持单线程编程.新的C++标准(称为C++11或C++0x)于2011年发布.在C++11中,引入了新的线程库.因此运行本文程序需要C++至少符合C++11标准. 文章目录 6 事件处 ...
- (二)elasticsearch 源码目录
在阅读源码之前,我们先来看看整个项目的结构:(同(一)elasticsearch 编译和启动,我们使用版本7.4.0作为示例) .ci,持续集成配置 .github, 里面有 PULL_REQUEST ...
- TCS34725 颜色传感器设备驱动程序
一.概述 以前的传感器是用过中断的方式进行计数的,现在已经有 I2C 通行的颜色传感器,不在需要我们像之前那样,通过计数的方式获取数据,直接通过I2C读取即可.当然有通过串口的方式获取采集数据的,串口 ...
- Java入门及环境搭建
1.JAVA三大版本 JAVASE(标准版:桌面程序开发.控制台开发...) JAVAME(嵌入式:手机程序.小家电...) JAVAEE(企业级:web端.服务器开发...) 2.开发环境 JDK: ...
- 《Effective C++》构造、析构、赋值运算
Item 05:了解C++默默编写并调用了哪些函数 总结:编译器可以暗自为class创建default 构造函数.copy构造函数.copy assignment操作符,以及析构函数. (这一小节比较 ...
- ORM执行原生SQL语句、双下划线数据查询、ORM外键字段的创建、外键字段的相关操作、ORM跨表查询、基于对象的跨表查询、基于双下划线的跨表查询、进阶查询操作
今日内容 ORM执行SQL语句 有时候ROM的操作效率可能偏低 我们是可以自己编写sql的 方式1: models.User.objects.raw('select * from app01_user ...
- vue中使用echarts来绘制中国地图,NuxtJS制作疫情地图,内有详细注释,我就懒得解释了,vue cli制作疫情地图 代码略有不同哦~~~
我的代码自我感觉----注释一向十分详细,就不用过多解释都是什么了~~ 因为最近疫情期间在家实在是没事干,想找点事,就练手了个小demo 首先上 NuxtJs版本代码,这里面 export defau ...