python树莓派通过队列实现进程交互的程序分析


Posted in Python onJuly 04, 2021

写在前面

现在购物车有一任务需求,那就是需要进行图像识别和运动控制,因此需要初始化2个进程,从而分别完成相应的动作。因为运动控制需要图像识别的结果,因此现在就涉及到了python语法实现2个进程之间的协同合作,这篇博客就结合实际的python程序通过队列实现进程交互通过队列实现进程交互

程序分析

首先介绍一下我们的需要的库函数:

import time
from multiprocessing import Process, Queue

from multiprocessing import Process, Queue是主要的库,作用就是提供队列和进程操作函数,在本次测试中我们用的的进程和队列操作函数有:

q1.get()#获取q1队列里的内容
q1.put("q1 put things1")#往q1队列里面加入内容
p1 = Process(target=test1, args=(q1, q2))#初始化p1进程
p1.start()#启动p1进程
p1.join()#将p1进行加入系统调度
q1.qsize()#查看q1队列的大小

测试中的线程与进程对应关系:

q1队列 -> q1进程
q2队列 -> q2进程

有了上述的基本函数之后就可以来看我们的程序实现了,可以看到在程序中首先进行了进程的初始化,启动和加入系统调度,运行完这些语句之后就可以认为p1和p2进程初始化好了。

p1 = Process(target=test1, args=(q1, q2))
p2 = Process(target=test2, args=(q1, q2))

p1.start()
p2.start()

p1.join()
p2.join()

进程初始化完毕之后就可以来看主要的测试函数了,首先是test1

def test1(q1, q2):
    q1.put("fisrt data")
    while(1):
        s = q2.get()
        print('q2 left + ' + str(q2.qsize()))
        print('q1 get + ' + s)
        q1.put("q1 put things1")
        q1.put("q1 put things2\n")
        time.sleep(1)

在之前的初始化函数中,我们是先初始化了p1进程,也就是test1会先运行,因此为了保证在开始的时候进程的队列里面有内容,我先在函数的最开始就在q1队列中加入了内容“fisrt data”,为了保证测试持续进行,因此我将test1进程设成了死循环,在test1中,会先去获取q2队列里的内容和q2队列大小并打印,然后会在q1队列中放入新的内容,请注意,这里放入了2个节点的数据,分别是“q1 put things1”和“q1 put things2\n”

在这里我提出一个问题:

那就是当p1进程去获取q2队列里的内容的时候,p1进程会将q2队列里的全部内容都取出还是只会取出q2队列最前面的那个数据呢?

接下来我们就来解决一下这个问题。接下来我们来看一下test2函数里面干了些什么:

def test2(q1, q2):
    while(1):
        s = q1.get()
        print('q1 left + ' + str(q1.qsize()))
        print('q2 get + ' + s)
        q2.put("q2 put data1")
        time.sleep(1)

test2函数中做的事情就比较少了,就是先获取了q1队列中的数据和q1剩余队列大小并打印,接着往q2队列加入“q2 put data1”。

结果分析

我们来看一下main函数里面的调用:

if __name__ == '__main__':
    p1 = Process(target=test1, args=(q1, q2))
    p2 = Process(target=test2, args=(q1, q2))

    p1.start()
    p2.start()

    p1.join()
    p2.join()

在main函数里面只是做了线程启动的操作,我们再来看一下输出结果:

python树莓派通过队列实现进程交互的程序分析

从结果中我们可以很清楚的看到,q1线程每次会加入2个节点数据,然后p2进程会从q1线程中做q1.get()的操作,随着循环次数的不断增加,我们可以发现q1队列的长度不断增加,从而我们可以得出结论:
p1进程去获取q2队列里的内容的时候,p1进程会将q2队列最前面的那个数据取出

到此这篇关于python树莓派通过队列实现进程交互的程序分析的文章就介绍到这了,更多相关python树莓派进程交互内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
OpenCV2.3.1+Python2.7.3+Numpy等的配置解析
Jan 05 Python
python opencv 图像尺寸变换方法
Apr 02 Python
python之线程通过信号pyqtSignal刷新ui的方法
Jan 11 Python
Django JWT Token RestfulAPI用户认证详解
Jan 23 Python
python实现贪吃蛇游戏
Mar 21 Python
Python判断对象是否为文件对象(file object)的三种方法示例
Apr 26 Python
python删除列表元素的三种方法(remove,pop,del)
Jul 22 Python
复化梯形求积分实例——用Python进行数值计算
Nov 20 Python
python隐藏类中属性的3种实现方法
Dec 19 Python
python和php哪个容易学
Jun 19 Python
Python之字符串的遍历的4种方式
Dec 08 Python
ASP.NET Core中的配置详解
Feb 05 Python
Python多线程 Queue 模块常见用法
Jul 04 #Python
python 中yaml文件用法大全
Jul 04 #Python
python3实现常见的排序算法(示例代码)
用Python编写简单的gRPC服务的详细过程
Jul 04 #Python
python中__slots__节约内存的具体做法
Jul 04 #Python
python中Matplotlib绘制直线的实例代码
Jul 04 #Python
C站最全Python标准库总结,你想要的都在这里
You might like
咖啡的传说和历史
2021/03/03 新手入门
PHP使用CURL获取302跳转后的地址实例
2014/05/04 PHP
PHP封装的HttpClient类用法实例
2015/06/17 PHP
php获取网站百度快照日期的方法
2015/07/29 PHP
PHP+swoole+linux实现系统监控和性能优化操作示例
2019/04/15 PHP
PHP中16个高危函数整理
2019/09/19 PHP
兼容Mozilla必须知道的知识。
2007/01/09 Javascript
JavaScript判断一个URL链接是否有效的实现方法
2011/10/08 Javascript
基于JavaScript实现继承机制之构造函数方法对象冒充的使用详解
2013/05/07 Javascript
使用闭包对setTimeout进行简单封装避免出错
2013/07/10 Javascript
javascript简单实现命名空间效果
2014/03/06 Javascript
JavaScript实现twitter puddles算法实例
2014/12/06 Javascript
js仿新浪微博消息发布功能
2017/02/17 Javascript
Javascript实现倒计时时差效果
2017/05/18 Javascript
label+input实现按钮开关切换效果的实例
2017/08/16 Javascript
JavaScript防止全局变量污染的方法总结
2018/08/02 Javascript
React降级配置及Ant Design配置详解
2018/12/27 Javascript
vue+element实现表格新增、编辑、删除功能
2019/05/28 Javascript
详解vue v-model
2020/08/31 Javascript
centos下更新Python版本的步骤
2013/02/12 Python
Python使用asyncio包处理并发详解
2017/09/09 Python
python中urlparse模块介绍与使用示例
2017/11/19 Python
完美解决在oj中Python的循环输入问题
2018/06/25 Python
python bmp转换为jpg 并删除原图的方法
2018/10/25 Python
IntelliJ IDEA安装运行python插件方法
2018/12/10 Python
Python面向对象之类的定义与继承用法示例
2019/01/14 Python
Python 限制线程的最大数量的方法(Semaphore)
2019/02/22 Python
Python 调用有道翻译接口实现翻译
2020/03/02 Python
Python常用GUI框架原理解析汇总
2020/12/07 Python
利用Python实现最小二乘法与梯度下降算法
2021/02/21 Python
利用 Canvas实现绘画一个未闭合的带进度条的圆环
2019/07/26 HTML / CSS
Becextech新西兰:数码单反相机和手机在线商店
2018/04/27 全球购物
泰国网上购物:Shopee泰国
2018/09/14 全球购物
ALDO美国官网:加拿大女鞋品牌
2018/12/28 全球购物
云南省召开党的群众路线教育实践活动总结会议新闻稿
2014/10/21 职场文书
前端JS获取URL参数的4种方法总结
2022/04/05 Javascript