ImageVerifierCode 换一换
格式:DOCX , 页数:12 ,大小:776.40KB ,
资源ID:2302313      下载积分:8 金币
快捷注册下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/2302313.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请

   平台协调中心        【在线客服】        免费申请共赢上传

权利声明

1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:0574-28810668;投诉电话:18658249818。

注意事项

本文(实验四-同步与互斥-Linux实验报告.docx)为本站上传会员【快乐****生活】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4009-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

实验四-同步与互斥-Linux实验报告.docx

1、 实验四 同步与互斥 【实验目的和要求】 1、掌握进程(线程)的同步与互斥。 2、掌握生产者消费者问题的实现方法。 3、掌握多线程编程方法。 【实验内容】 实现生产者消费者问题 1、有一个仓库,生产者负责生产产品,并放入仓库,消费者会从仓库中拿走产品(消费)。 2、仓库中每次只能入一个(生产者或消费者)。 3、仓库中可存放产品的数量最多10个,当

2、仓库放满时,生产者不能再放入产品。 4、当仓库空时,消费者不能从中取出产品。 5、生产、消费速度不同。 【实验原理】 1、 信号量mutex提供对缓冲池访问的互斥要求并初始化为1,信号量empty和full分别用来表示空缓冲项和满缓冲项的个数,信号量empty初始化为n,信号量full初始化为0。 2、定义如下结构及数据:   定义缓冲区内的数据类型:typedef int buffer_item;  缓冲区 :buffer_item buffer[BUFFER_SIZE]; 对缓冲区操作的变量:int in,out;  信号量mu

3、tex提供了对缓冲池访问的互斥要求:pthread_mutex_t mutex;  信号量empty和full分别表示空缓冲顶和满缓冲顶的个数:sem_t empty,full;  可以设定生产者的生产速度及消费者的消费速度 :int pro_speed,con_speed; 对缓冲区操作的自增函数:#define inc(k) if(k < BUFFER_SIZE) k = k+1;else k=0 3、并定义了如下实现问题的函数模块:  将生产的产品放入缓冲区: int insert_item(buffer_item item)       从缓冲区内移走一个产品: int

4、 remove_item(buffer_item *item)     生产者进程 :void *producer(void *param)          消费者进程:void *consumer(void *param)      生产者结构进程 消费者结构进程 【程序代码】 //sx.c #include #include #include #include #inclu

5、de #define inc(k) if(k

6、speed,con_speed;//可以设定生产者的生产速度及消费者的消费速度 int insert_item(buffer_item item) {//将生产的产品放入缓冲区 buffer[in]=item; printf("******insert缓冲池第%d号******\n",in); inc(in); } int remove_item(buffer_item *item) {//从缓冲区内移走一个产品 *item = buffer[out]; printf("******remove缓冲池第%d号******\n",out); inc(out); } v

7、oid *producer(void *param) {//生产者进程 buffer_item item; int num = 0; while(1) { sleep(rand()%(16-pro_speed)); printf("\n******第%d次生产******\n",++num); printf("******等待empty信号******\n"); sem_wait(&empty); printf("******等待解锁******\n"); pthread_mutex_lock(&mutex); printf("******上锁,准备生产******\n

8、"); item = rand()%1000+1; printf("******生产产品%d*******\n",item); insert_item(item); printf("*******解锁******\n"); printf("******第%d次生产结束*******\n\n",num); pthread_mutex_unlock(&mutex); sem_post(&full); } } void *consumer(void *param) {//消费者进程 buffer_item item; int num = 0; while(

9、1){ sleep(rand()%(16-con_speed)); printf("\n******第%d次消费*****\n",++num); printf("******等待full信号******\n"); sem_wait(&full); printf("******等待解锁******\n"); pthread_mutex_lock(&mutex); printf("******上锁,准备消费******\n"); remove_item(&item); pthread_mutex_unlock(&mutex); sem_post(&empty); printf

10、"******消费产品%d*******\n",item); printf("*******解锁******\n"); printf("******第%d次消费结束*******\n\n",num); } } int main()//主函数 { pthread_t tid1,tid2; pthread_attr_t attr1,attr2; srand(time(NULL)); pthread_mutex_init(&mutex,NULL);//初始化 sem_init(&empty,0,BUFFER_SIZE); sem_init(&full,0,0);

11、 in=0; out=0; printf("***********************\n"); printf("********开始!***********\n"); printf("***********************\n"); printf("生产者速度(1-15):\n"); scanf("%d",&pro_speed); printf("消费者速度(1-15):\n"); scanf("%d",&con_speed); pthread_attr_init(&attr1); pthread_create(&tid1,&attr1,producer,N

12、ULL); pthread_attr_init(&attr2); pthread_create(&tid2,&attr2,consumer,NULL); sleep(100); printf("*******程序over*******\n"); return 0; } 【实验步骤】 编写程序代码gedit sx.c,再对代码进行编译gcc sx.c –o sx –lpthread,编译无错误,进行运行./sx,根据提示要求进行填写生产者和消费速度,观察消费者和生产者进程。 【实验结果】 【实验体会】 1、Linux中生成

13、线程方法: 第一种方式是用pthread 库来实现的,是在用户程序本身中实现线程,这实际上是对线程的一种模拟,线程之间的切换和调度是在用户的进程内部进行的,这种方式就被称为用户空间的线程。 这种线程的好处是实现非常简单,性能也非常好,因为线程之间的切换都在用户进程内部进行,切换开销比较小。缺点也非常明显,首先就是不能充分利用高端系统的SMP多处理器的优点,因为一个进程只能由一个处理器处理,第二点由于用户空间是在用户空间切换,某个线程遇到一个需要阻塞的系统调用进而就会造成这个进程被阻塞,因而所有线程被阻塞。 第二种方式是通过修改进程的实现方式来完成,可以使用不完全的进程创建方

14、式创建共享数据空间的进程,在Linux下这种系统调用为clone()。 2、Ptrtead生成线程: POSIX thread简称为pthread,Posix线程是POSIX标准线程该标准定义内部API创建和操纵线程。 数据类型 pthread_t: 线程句柄 pthread_attr_t: 线程属性 线程操纵函数(省略参数): pthread_create():创建一个线程 pthread_exit():终止当前线程 pthread_cancel():中断另外一个线程的运行 pthread_join():阻塞当前的线程,直到另外一个线程运行结束 pthread_attr_init():初始化线程的属性 pthread_attr_setdetachstate():设置脱离状态的属性(决定这个线程在终止时是否可以被结合) pthread_attr_getdetachstate():获取脱离状态的属性 pthread_attr_destroy():删除线程的属性 pthread_kill():向线程发送一个信号 Welcome To Download !!! 欢迎您的下载,资料仅供参考! 精品资料

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2026 宁波自信网络信息技术有限公司  版权所有

客服电话:0574-28810668  投诉电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服