- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
操作系统课程计设报告模板
西安郵電大學
操作系统设计报告
题 目:进程、线程、互斥锁
院系名称: 计算机学院
专业名称: 软件工程
班 级: 1104
学生姓名: 赵大伟
学号(8位)指导教师: 舒新峰
设计起止时间:2013.11.10—2013.11.20
设计目的
通过观察、分析实验现象,深入理解进程及进程在调度执行和内存空间等方面的特点,掌握在POSIX 规范中fork和kill系统调用的功能和使用。
通过观察、分析实验现象,深入理解线程及线程在调度执行和内存空间等方面的特点,并掌握线程与进程的区别。掌握POSIX 规范中pthread_create() 函数的功能和使用方法。
通过观察、分析实验现象,深入理解理解互斥锁的原理及特点掌握在POSIX 规范中的互斥函数的功能及使用方法。
二. 设计内容
1)创建一个进程,父子进程 相互交替执行,输出子进程号和进程ID
2)创建三个线程,输出三个线程运行的次数和当前主线程运行次数以及三个线程次数和。
3)使用POSIX 规范中的互斥函数,实现加锁解锁
4)信号量机制的方法,实现进程的加锁解锁,且不产生死锁
概要设计
1)生成一个进程,通过switch()判断,来确定生成的进程是子进程还是父进程,还是错误的;子进程号定义为全局变量;利用kill()杀死进程,退出程序。
2)利用循环创建三个线程,do while循环,每运行一次:输出三个线程运行的次数,当输入q时候,退出程序。
3)创建一个线程,在循环中进行申请资源,释放资源,加锁,以及解锁的操作,熟悉互斥锁的工作方式。
详细设计
1)进程交替进行
当程序执行到for(i = 0; i child_proc_number; i++)循环后,调用fork()函数创建第一个子进程,然后父进程与该子进程交替执行,当子进程抢到cpu时继续往下执行case 0:语句中的do_something();语句,执行死循环for(;;)输出该进程的相关内容,并sleep,给其他进程抢占cpu的机会。这样就会使得进程交替的执行。
kill命令杀死进程
while ((ch = getchar()) != q) {
if (isdigit(ch)) {
i=ch-0;kill(pid[i],SIGTERM);
}
}
for(i=0;i10;i++){
kill(pid[i],SIGTERM);
}
return;
}
进程运行次数
do { unsigned long long sum = 0;
for (i=0; iMAX_THREAD; i++) {
sum += counter[i];
printf(%llu\n , counter[i]);
}
printf(%llu/%llu\n, main_counter, sum);
} while ((ch = getchar()) != q);
进程加锁,解锁
a、for(i = 0; i LOOP_TIMES; i++)
{
pthread_mutex_lock(mutex1);
pthread_mutex_lock(mutex2);
critical_section(1,i);
pthread_mutex_unlock(mutex2);
pthread_mutex_unlock(mutex1);
}
pthread_mutex_destroy(mutex1);
pthread_mutex_destroy(mutex2);
b、for (i = 0; i LOOP_TIMES; ++i) {
sem_wait(S1);
sem_wait(S2);
critical_section(1, i);
sem_post(S1);
sem_post(S2);
}
sem_destroy(S1);
sem_destroy(S2);
五.测试数据及运行结果
进程.
各进程交替执行。无确定顺序
当输入要删除的进程编号时会调用一次kill,最后输入q结束时会调用一次kill。
输入q则显示“已终止”,整个程序执行结束。
2)线程
输出个各线程运行的次数,main_counter和sum的值
3)互斥锁
2.异常测试数据及运行结果
死锁:
您可能关注的文档
- 2019年三年级数学上册第8单元探索乐园知识与技能教学建议冀教版.doc
- 执业护士考试妇《产科护理学》试题.doc
- 2019年三年级数学上册第8单元探索乐园装饰方案教学建议冀教版 .doc
- 执业护士实践力能模拟试题四A型题.docx
- 电子商务作业答及案网上选修.doc
- 执业药师历年试考题和答案.doc
- 2019年三年级数学上册第8单元探索乐园装饰方案教学建议冀教版.doc
- 电子商务中的OO以宁苏和沃尔玛为例.docx
- 执业药师考试习复资料及模拟试题库答案解析汇总(五).docx
- 2019年三年级数学上册第8单元探索乐园问题思考教学建议冀教版 .doc
- 2019年三年级数学下册 第1单元第5课时《练习一》同步测试(2) 苏教版.doc
- 操作系统课程计设试验报告格式.doc
- 2019年三年级数学下册 第3单元第2课时《从问题出发思考的策略》同步练习 苏教版.doc
- 2019年三年级数学下册 第3单元第3课时《练习四》同步测试(1) 苏教版.doc
- 攀枝花学院外语国学院第七届外语文化月闭幕式暨外国语学院毕业生晚会方案.doc
- 盘点曼彻斯特学大各类硕士专业申请要求.docx
- 2019年三年级数学下册 第3单元第4课时《练习四》同步测试(2) 苏教版.doc
- 盘点月薪最高1的0大高职专业.docx
- 2019年三年级数学下册 第4单元第1课时《乘法和加、减法的混合运算》同步练习 苏教版.doc
- 支付宝运营、利盈模式分析.doc
文档评论(0)