实验二linux操作系统.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验二linux操作系统

嵌入式操作系统—多线程-实验报告 程序实验2:多线程编程实验 实验周次 9 实验日期 2014/4/20 姓名 张括 学号 实验一(p284:11-thread.c) 1、软件功能描述 创建线程实际上就是确定调用该线程函数的入口点,通常使用的函数是pthread_create()。在线程创建以后,就开始运行相关的线程函数,在该函数运行完之后,该线程也就退出,这是线程退出一种方法。另一种退出线程的方法是使用函数pthread_exit(),这是线程的主动行为。 本实验程序创建了3个线程,这3个线程重用一个函数,每个线程循环5次,随机等待1-10s时间。 2、程序流程设计 任务完成? 所有线程执行完成? 是 是 结束所有线程 结束 否 否 开始 创建线程 定义创建线程数和每个线程中任务数 随机运行线程任务 3.部分程序代码注释(关键函数或代码) …… /* thread.c */ #include stdio.h #include stdlib.h #include pthread.h #define THREAD_NUMBER 3 #define REPEAT_NUMBER 5 #define DELAY_TIME_LEVELS 10.0 void * thrd_func(void *arg) { int thrd_num = (int)arg; int delay_time = 0; int count = 0; 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)); 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); } } return 0; } …… 4.编译、运行方法及结果(抓屏) 5.结果分析 …… 通过上述实验,根据运行结果可以看出程序中创建了三个线程,且每个线程中的5个任务循环等待时间是随机的,这样任务到达的时间也是随机的,所以线程2中的任务可能会比线程1的任务线执行,即线程2可能会比线程1先运行结束。 实验二(p287: 11-thread_mutex.c) 1、软件功能描述 由于线程共享进程的资源和地址空间,因此在对这些资源进行操作的时候,必须考虑到线程间资源访问的同步与互斥问题。本实验主要利用互斥锁机制,保证让每个线程对共享资源按顺序进行原子操作。用一种简单的加锁方法来控制对共享资源的原子操作。 互斥锁只有两种状态:上锁和解锁,可以把互斥锁看作某种意义上的全局变量。同一时刻只能有一个线程掌握某个互斥锁,拥有上锁状态的线程能够对共享资源进行操作。若其他线程希望访问一个已经被上锁的互斥锁,则该线程就会挂起,直到上锁的线程释放掉互斥锁为止。 互斥锁保证每个线

文档评论(0)

2017ll + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档