
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、嵌入式linux中的进程同步无竞争态读写在对实时采集更新的数据举行处理时,往往会碰到数据更新速度与数据处理的速度不匹配的问题。这种状况下,会浮现数据走失而导致数据处理结果不精确,甚至会带来不行预测的后果,因此需要一种机制来协调数据更新与数据处理,从而保证数据的完整性和处理结果的精确性。作为一个多任务、多用户操作系统,支持多个进程在系统中并发运行,因为进程本身的动态特性,用来描述实时数据处理十分合适,因此,解决好linux进程间的同步与通信问题就能解决实时数据处理的问题。在linux环境下,进程通常存在运行(running)、堵塞(blocked)、就绪(ready)、终止(terminated
2、)四种状态。当多个进程并发执行时,往往会浮现进程间的竞态。我们希翼进程能协调彼此间的行为,使得一个进程惟独在其他的进程执行到一个特定的点时才会执行一个动作,即控制同步;同时,当并发进程拜访分享数据时不应该浮现竞争条件。这一点通过在拜访分享数据时执行互斥来确保,即数据拜访同步。实现同步的基本技术是堵塞一个进程,直到一个特定条件满足为止;实现数据拜访同步是通过堵塞一个进程直到另外的进程完成拜访分享数据。1 有限长度缓冲区的生产者一消费者问题模型当仅存在单个生产者和消费者时,生产进程和消费进程所对应的是同样的数据结构,它们分享同一个数据空间。生产进程和消费进程如何举行互相协调,使得消费进程每次用法的
3、数据都是生产进程新生产写人的,又使生产进程新写入的数据不会笼罩还未被消费进程读出访用的数据,是该问题模型实现的关键问题。在生产者一消费者问题模型中,生产者进程不断生产产品并把它们放入缓冲区,消费者进程不断从缓冲区中取走产品举行消费。当缓冲区中产品已经放满时,表示生产速度高于消费速度,浮现了供过于求,此时生产者必需等待产品被消费;当缓冲区为空时,表示消费速度高于生产速度,浮现了供不应求,此时消费者进程必需等待产品的生产。生产和消费的进程必需达到同步运行,才干实现供需平衡。处理读写同步的两种频繁的策略被称为“强读者同步(strong reader synchronization)”和“强写者同步(
4、strongwriter synchronization)”。在强读者同步中,总是给读者以优先权,只要写者当前没有举行写操作,读者就可以获得拜访权;在强写者同步中,写者总是获得优先权,只要强读者当前没有举行读操作,写者就可以获得拜访权。而生产者消费者同步与单纯的读写同步又有不同,消费者可以通过拜访资源对资源举行删除或销毁。一个有限长度缓冲区的生产者消费者问题模型,是由若干生产者和消费者进程以及一个有限的缓冲池构成的。每个缓冲区能够存储一个信息记录,一个生产者一次生产一个信息记录。产生一个记录之后,等待单独进入一个空的缓冲区后将记录写入缓冲区。一个消费者进程一次消费一个信息记录。当它需要消费时,
5、它等待单独进入一个满的缓冲区后将记录读出。通过上面的描述可以得出,解决生产者一消费者问题模型的计划需要满足以下几个条件:生产者不应笼罩一个满的缓冲区;消费者不应用法一个空的缓冲区;生产者和消费者应按互斥方式拜访数据缓冲区;数据必需根据先进先出(fifo)方式;不能浮现忙等待。必需避开数据写进程不断、反复地检查缓冲区直到找到一个空缓冲区为止,而读进程也必需避开不断检查直到找到一个满缓冲区为止。这相当于系统内部产生忙等待,是在仅用法临界段(cs)算法实现进程同步时难以避开的问题。针对问题模型解决计划的限制条件,采纳信号量方式解决实时更新数据处理的进程同步问题,即上述的生产者一消费者问题模型。信号量
6、是一个非负值的分享整数值,只能用于初始化和不行分操作。不行分操作是指在对一个数据d举行操作时不能与任何其他对d的操作重叠的操作。定义操作p和v为不行分操作。p和v的不行分性意味着这些操作不能并发执行,避开了对信号量的竞争条件。定义p和v的操作语义为:由上述定义的语义看,对一个信号量s的操作,p和v为转变s的值,或者挂起或唤醒一个对s举行p操作的进程。被挂起的进程为堵塞状态,因而避开了忙等待问题。一个二进制的信号量只取0和1,用来实现互斥。在p和v操作中,对进程的堵塞和唤醒需要操作系统的进程管理组件的参加,因此信号量会被操作系统实现而不是应用程序实现。生产者一消费者问题模型描述:2 结构设计对于
7、有限缓冲区的生产者消费者问题模型的执行包括以下部件:分享数据一缓冲区组、操作一缓冲区的拜访、进程一生产者消费者。在生产者一消费者同步中,由生产者创建资源,与单纯的读程序不同,消费者可以通过拜访资源,将资源删除或销毁。因为生产者进程和消费者进程分享一个缓冲区,因此在插入和删除条目时必需同步。实现中必需避开表l所列的同步异样问题。生产者一消费者问题的传统的信号量解决计划用法了2个信号量,分离用来表示缓冲区中的条目数和空闲槽的数目。当进程需要特定类型的资源时,它可以通过函数调用对相应的信号量举行减量操作;同样,当进程释放资源时,它可以通过函数调用来对相应的信号量举行增量操作。因为信号量永久不会降到零
8、以下,所以进程不能用法不存在的资源。因此,始终将计数信号量初始化为开头时可用的资源数。定义循环队列缓冲区存放待处理数据,控制台数据处理进程从该循环队列缓冲区中消费数据,并将该数据存储位标志为“废弃”。数据采集写进程仅能将数据存放于标志为“废弃”的循环队列缓冲区中,1所示。在没有多个生产者或消费者的状况下,假如认真实现,循环缓冲区就不需要锁。生产者是唯一允许修改写入索引以及该索引指向的数组位置的进程。只要写入者在更新写入索引之前将新的值保存到缓冲区,则读取者将始终看到全都的数据结构;同时,读取者是唯一可以拜访读取索引以及该索引指向位置的数据的进程。只要确保两个指针不要相互重叠,生产者和消费者可以
9、在无竟态的状况下拜访该缓冲区,2所示。对于惟独单个生产者和消费者,通过用法修正的用法信号量方式的生产者一消费者问题模型解决计划来实现。以上用信号量方式解决了优先缓冲区问题,信号量“empty”和“full”的值分离指示空和满的缓冲区的数量,3所示。缓冲区指针i和j用来确保缓冲区按先进先出的挨次提供并用法。只要系统中存在一些满的和空的缓冲区,数据更新进程和数据处理进程就能无竞态并发执行。笔者在华恒平台hharm2410-r5上根据上述计划胜利实现了用例测试。3 研究以上的结构设计,将生产者与消费者分离简化为一个。当存在多个生产者和消费者的状况时,可以上述修正的解决计划为基础,设计多个计数器来统计并行读者(reader)、并行写者(writer)、读者或待读者(pre_reader)、写者或待写者(pre_writer)的数量。计数器的值在进程中的相应位置举行增减。读者和写者在被允许阅读和写入之前必需被堵塞,这可以通过p操作来完成。当读
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 电力干线迁移施工方案
- 新中式瓦工施工方案
- 文官街地铁施工方案
- TSHPA 0006-2024 学校有害生物综合管理指南
- 2025年度跨境电商贷款担保合同
- 二零二五年度餐饮管理辅导合同
- 二零二五年度柜台品牌授权与推广合同
- 茶楼茶艺师劳动合同2025年度与劳动合同签订流程
- 二零二五年度影视演员网络直播聘用协议
- 二零二五年度个体店面转让与市场准入条件协议
- 弟子规42+用人物须明求+教案
- 施工钢板桩监理细则
- 微电网-储能电池catl pet80ah电芯规格书
- GB/T 4209-2022工业硅酸钠
- 2023年江苏农林职业技术学院高职单招(数学)试题库含答案解析
- GB/T 39242-2020无损检测超声检测灵敏度和范围设定
- GB/T 32271-2015电梯能量回馈装置
- GB/T 18775-2009电梯、自动扶梯和自动人行道维修规范
- GB/T 1.2-2020标准化工作导则第2部分:以ISO/IEC标准化文件为基础的标准化文件起草规则
- 《社会历史的决定性基础》课件2 【知识建构+备课精研】统编版高中语文选择性必修中册
- 消毒供应中心火灾应急预案演练记录
评论
0/150
提交评论