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