实验4基于信号量的线程控制.doc.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
实验4基于信号量的线程控制.doc.doc

实验4 基于信号量的线程控制 实验目的:利用信号量实现线程间的同步与互斥 实验内容 2.1实验内容1:利用锁实现线程间的互斥 互斥锁是用一种简单的加锁方法来控制对共享资源的原子操作。这个互斥锁只有两种状态,也就是上锁和解锁,可以把互斥锁看作某种意义上的全局变量。在同一时刻只能有一个线程掌握某个互斥锁,拥有上锁状态的线程能够对共享资源进行操作。若其他线程希望上锁一个已经被上锁的互斥锁,则该线程就会挂起,直到上锁的线程释放掉互斥锁为止。可以说,这把互斥锁保证让每个线程对共享资源按顺序进行原子操作。 互斥锁机制主要包括下面的基本函数。 互斥锁初始化:pthread_mutex_init() 互斥锁上锁:pthread_mutex_lock() 互斥锁判断上锁:pthread_mutex_trylock() 互斥锁接锁:pthread_mutex_unlock() 消除互斥锁:pthread_mutex_destroy() 以下是实验3中程序的改进版,调试运行以下程序 #include stdio.h #include stdlib.h #include pthread.h #define THREAD_NUMBER 3 #define REPEAT_NUMBER 3 #define DELAY_TIME_LEVELS 10.0 pthread_mutex_t mutex; void * thrd_func(void *arg) { int thrd_num = (int)arg; int delay_time = 0, count = 0; int res; res = pthread_mutex_lock(mutex); if (res) { printf(Thread %d lock failed\n, thrd_num); pthread_exit(NULL); } printf(Thread %d is starting\n, thrd_num); for (count = 0; count REPEAT_NUMBER; count++) { delay_time = (int)(rand() * DELAY_TIME_LEVELS/(RAND_MAX)) + 1; sleep(delay_time); printf(\tThread %d: job %d delay = %d\n, thrd_num, count, delay_time); } printf(Thread %d finished\n, thrd_num); pthread_exit(NULL); } int main(void) { pthread_t thread[THREAD_NUMBER]; int no = 0, res; void * thrd_ret; srand(time(NULL)); pthread_mutex_init(mutex, NULL); for (no = 0; no THREAD_NUMBER; no++) { res = pthread_create(thread[no], NULL, thrd_func, (void*)no); if (res != 0) { printf(Create thread %d failed\n, no); exit(res); } } printf(Create treads success\n Waiting for threads to finish...\n); for (no = 0; no THREAD_NUMBER; no++) { res = pthread_join(thread[no], thrd_ret); if (!res) { printf(Thread %d joined\n, no); } else { printf(Thread %d join failed\n, no); } pthread_mutex_unlock(mutex); } pthread_mutex_destroy(mutex); return 0; } 问题1:运行结果与实验2中的比较有何不同? 2.2实验内容2:利用信号量实现生产者与消费者问题 信号量与PV原子操作广泛用于进程或线程间的同步与互斥。以下为信号量机制的相关函数: sem_init()用于创建一个信号量,并初始化它的值。 sem_wait()和sem_trywait()都相当于P操作,在信号量

文档评论(0)

170****0532 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:8015033021000003

1亿VIP精品文档

相关文档