首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
自考
编一个C程序,使用户进程的全局变量作为输入输出的缓冲区,线程1一次读入一个字符串,将其存入缓冲区,线程2从缓冲区取出数据,输出打印,用线程的条件变量实现两个线程间的同步。程序调试成功后用I/O转向再测试程序,标准输入输出都改为文件。 可以用条件变量实现线程
编一个C程序,使用户进程的全局变量作为输入输出的缓冲区,线程1一次读入一个字符串,将其存入缓冲区,线程2从缓冲区取出数据,输出打印,用线程的条件变量实现两个线程间的同步。程序调试成功后用I/O转向再测试程序,标准输入输出都改为文件。 可以用条件变量实现线程
admin
2016-05-14
47
问题
编一个C程序,使用户进程的全局变量作为输入输出的缓冲区,线程1一次读入一个字符串,将其存入缓冲区,线程2从缓冲区取出数据,输出打印,用线程的条件变量实现两个线程间的同步。程序调试成功后用I/O转向再测试程序,标准输入输出都改为文件。
可以用条件变量实现线程之间的同步。条件变量就像是一面旗子,用于通知需要同步的进程。条件变量函数总是和互斥锁在一起使用。与一般的锁变量不同,与条件变量相关锁的常态是锁住的,而在执行了pthread_cond_wait(&flag,&lock)等待条件变量后,互斥锁lock就打开了,然后等待条件变量的变化。如果在调用此函数之前,互斥量没有被锁住,函数执行的结果是不确定的。在该函数返回之前,该函数自动将指定的互斥量重新锁住。
pthread_cond_slgnal函数通过条件变量发消息。若有多个线程都在等待,只唤醒它们中的一个,但一般只用于一个线程等待该条件变量。
有关的函数和操作定义如下:
#include<pthread.h>
#include<ctype.h>
pthread_mutex_t mutex=PTHREAD_MOTEX_INITIALIZER; /*初始化锁*/
pthread_cond_t cond=PTHREAD_COND_INITIALIZER; /*初始化条件变量*/
pthread_cond_wait(pthread_cond_t*cond,pthread_mutex_t*mutex);
/*等待条件变量cond,开互斥锁mutex*/
pthread_cond_signal(pthread_cond_t*cond); /*通知条件变量cond状态变化*/
选项
答案
实现该功能的C程序为程序清单15-1。 有关的函数和操作定义如下: #include<pthread.h> #include<ctype.h> pthread_mutex_t mutex=PAHREAD_MUAEX_INIAIALIZER;/*初始化锁*/ pthread_cond_t cond=PAHREAD_COND_INIAIALIZER;/*初始化条件变量.*/ pthread_cond_wait(pthread_cond_t*cond,pthread_mutex_t*mutex); /*等待条件变量cond,开互斥锁mutex*/ pthread_cond_signal(pthread_cond_t*cond)j/*通知条件变量cond状态变化*/ 在程序清单15-1的pthread_cond.c中,主线程创建两个线程,线程1一次读入一个字符串,将其存入缓冲区,线程2从缓冲区取出数据,输出打印。主线程先初始化锁变量和条件变量值后,创建了两个线程,线程1通过pthread_cond_wait等待条件变量的变化。当一个线程将字符串存入缓冲区后,线程2将缓冲区中的字符串取出并打印,并用pthread_cond_signal通知线程1条件变量的变化,主线程就可将输入的字符串存人缓冲区,如此循环执行。 程序清单15-1.pthread_cond.C #include<stdio.h> #include<stdlib.h> #include<pthread.h> #include<ctype.h> pthread_mutex_t lock=PAHREAD_MUAEX_INIAIALIZER; /*初始化锁后,锁是关闭的*/ pthread_cond_t empty=PAHREAD_COND_INIAIALIZER;/*初始化条件变量l*/ pthread_cond_t full=PAHREAD_COND_INIAIALIZER;/*初始化条件变量2*/ char buf[256]; main() { pthread_t t1,t2;/*两个线程*/ void *put buf(void*);/*线程1执行的输入和存入缓冲区的函数*/ void *get buf(void*);/*线程2执行的从缓冲区读出和打印的函数*/ pthread_mutex_lock(&lock);/*先关闭锁,封锁对buf的访问*/ pthread_cond signal(&empty); pthread_create(&t1,NULL,put_buf1);/*创建线程1*/ pthread_create(&t2,NULL,get_buf);/*创建线程2*/ pthread_join(t1,NULL);/*等待子线程1结束*/ pthread_join(t2,NULL);/*等待子线程2结束*/ } void*put_buf()/*线程并发执行的函数1*/ { while(1){ pthread_cond_wait(&empty,&lock); /*等待条件变量状态变化(等待旗帜empty"升起"),开锁*/ printf("empty flag was raised,I have the lock\n"); /*条件变量已变化(旗帜empty已"升起"),获得了锁(锁已开)*/ pthread_mutex_lock(&lock);/*关锁,竞争buf*/ printf("pthreal:input string\n"); gets(buf);/*读入,存入缓冲区*/ pthread_mutex_unlock(&lock); pthread_cond_signal(&full);/*升起条件变量旗帜,通知线程2*/ /*升起旗帜,通知线程2,可再在buf存放结果*/ } } void*get_buf()/*线程并发执行的函数2*/ { sleep(2); while(1); pthread_cond_wait(&full,&lock); /*等待条件变量状态变化(等待旗帜full"升起"),开锁*/ printf("full flag was raised,I have the lock\n"); /*条件变量已变化(旗帜full已"升起"),获得了锁(锁已开)*/ pthread_mutex_lock(&lock);/*关锁,竞争buf*/ printf("thread2 output:%s\n",buf);/*从缓冲区取出,打印*/ pthread_cond_signal(&empty);/*升起条件变量旗帜,通知线程1*/ } }。
解析
转载请注明原文地址:https://kaotiyun.com/show/AYNx777K
本试题收录于:
操作系统题库理工类分类
0
操作系统
理工类
相关试题推荐
建设单位在开工前都必须依照《建筑工程施工许可管理办法》的规定,向工程所在地_______人民政府建设行政主管部门申请领取施工许可证。()
以下属于建设程序的主要阶段的是()
防火墙的目的在于实现安全访问控制,请根据防火墙的体系结构相关知识回答下列问题。本题图所示为某种防火墙的体系结构,试补充完整①~⑤处空缺的组件名称。可选组件名称:内部路由器、外部路由器、堡垒主机、内部主机、外部网络。
通常,可以利用____________这个简单命令得到主机操作系统的类型。
按照网络安全漏洞的可利用方式来划分,漏洞探测技术可以分为___________和攻击型漏洞探测两种。
加密主要是为了隐蔽信息的内容,而认证的三个主要目的是:消息完整性认证、___________消息的序号和操作时间认证。
某决策问题,面临O1、O2、O3、O4四个状态,有A1、A2、A3三个方案可供选择,其支付费用表如下表:试分别完成以下问题:(1)用乐观法决策。(2)用悲观法决策。(3)用最小最大遗憾值法决策。
在操作系统中,信号量表示资源的实体,是一个与队列有关的整型变量,其值仅能由()
在具有多线程机制的操作系统中,进程与线程的关系是()
进程从运行态转为就绪态,可能的原因是()
随机试题
下列不属于投标对象选择中可靠性评价的是()
Intermsofartisticvalue,itishardtosaythatonecountry’sartformisgreaterthan______.
可研末水调外敷,治口舌生疮的药是
中风之中脏腑与中经络的鉴别要点是( )。
在竞争导向定价法中,领导定价法所定价格处于较高价位,挑战定价法所定价格比市场领导者的定价稍低或低得较多,随行就市定价法所定价格为同类物业的平均现行价格水平。()
由于目标控制通常表现为一个有限的周期性循环过程,因此,目标控制是一种()
证券投资基金通过多样化的资产组合,可以分散资产的()。
下列“考”字,最有可能出现在秦朝官方文献中的是()。
昨天,关于媒体与网络爆出的“封口费"事件以及4件文物受损一事,故宫全部予以否认。对于近期不断有故宫内部人士向媒体__________的情况,有故宫工作人员__________,希望故宫不要再陷进“内斗”的__________。依次填入画横线部分最恰当的一项
A、Herunsastoresellingappliances.B、Heisamasterofceremonies.C、Heholdsafinancialconsultancy.D、Heisasalesmanage
最新回复
(
0
)