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 相关文章推荐
Python版的文曲星猜数字游戏代码
Sep 02 Python
Python数据结构之单链表详解
Sep 12 Python
深入理解Python中的super()方法
Nov 20 Python
python删除过期log文件操作实例解析
Jan 31 Python
tensorflow 输出权重到csv或txt的实例
Jun 14 Python
Linux下python3.7.0安装教程
Jul 30 Python
解决Python3 被PHP程序调用执行返回乱码的问题
Feb 16 Python
python3连接kafka模块pykafka生产者简单封装代码
Dec 23 Python
python实现ip地址的包含关系判断
Feb 07 Python
pip安装提示Twisted错误问题(Python3.6.4安装Twisted错误)
May 09 Python
matplotlib绘制鼠标的十字光标的实现(内置方式)
Jan 06 Python
一篇文章带你搞懂Python类的相关知识
May 20 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
php学习之 数组声明
2011/06/09 PHP
php json与xml序列化/反序列化
2013/10/28 PHP
php计算2个日期的差值函数分享
2015/02/02 PHP
有关PHP 中 config.m4 的探索
2020/08/26 PHP
javascript 实现父窗口引用弹出窗口的值的脚本
2007/08/07 Javascript
javascript基于jQuery的表格悬停变色/恢复,表格点击变色/恢复,点击行选Checkbox
2008/08/05 Javascript
js 实现在离开页面时提醒未保存的信息(减少用户重复操作)
2013/01/16 Javascript
js鼠标及对象坐标控制属性详细解析
2013/12/14 Javascript
jQuery中after()方法用法实例
2014/12/25 Javascript
Javascript实现检测客户端类型代码封包
2015/12/03 Javascript
JavaScript开发者必备的10个Sublime Text插件
2016/02/27 Javascript
javascript中对Date类型的常用操作小结
2016/05/19 Javascript
利用jQuery插件imgAreaSelect实现图片上传裁剪(放大缩小)
2016/12/02 Javascript
基于JS实现移动端向左滑动出现删除按钮功能
2017/02/22 Javascript
ComboBox(下拉列表框)通过url加载调用远程数据的方法
2017/08/06 Javascript
js实现canvas保存图片为png格式并下载到本地的方法
2017/08/31 Javascript
探索webpack模块及webpack3新特性
2017/09/18 Javascript
Vue实现验证码功能
2019/12/03 Javascript
JavaScript实现答题评分功能页面
2020/06/24 Javascript
详解JavaScript执行模型
2020/11/16 Javascript
[01:59]游戏“zheng”当时试玩会
2019/08/21 DOTA
python编写网页爬虫脚本并实现APScheduler调度
2014/07/28 Python
python使用itchat实现手机控制电脑
2018/02/22 Python
python爬虫爬取网页表格数据
2018/03/07 Python
python实现linux下抓包并存库功能
2018/07/18 Python
linux安装Python3.4.2的操作方法
2018/09/28 Python
python scp 批量同步文件的实现方法
2019/01/03 Python
详解Python实现进度条的4种方式
2020/01/15 Python
python小技巧——将变量保存在本地及读取
2020/11/13 Python
python opencv实现图像配准与比较
2021/02/09 Python
LODI女鞋在线商店:阿利坎特的鞋类品牌
2019/02/15 全球购物
三好学生主要事迹怎么写
2015/11/03 职场文书
大学组织委员竞选稿
2015/11/21 职场文书
2019消防宣传标语!
2019/07/10 职场文书
MySQL GTID复制的具体使用
2022/05/20 MySQL
javascript进阶篇深拷贝实现的四种方式
2022/07/07 Javascript