- 1、本文档共12页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
西安郵電大學
设计报告
题 目:
院系名称:计算机学院
专业名称:软件工程
班 级:1104
学生姓名:
学号(8位):
指导教师: 设计起止时间:—2013.11.20
设计目的通过观察、分析实验现象,深入理解进程及进程在调度执行和内存空间等方面的特点,掌握在POSIX fork和kill系统调用的功能和使用。
通过观察、分析实验现象,深入理解线程及线程在调度执行和内存空间等方面的特点,并掌握线程与进程的区别。掌握POSIX pthread_create() 函数的功能和使用方法。
通过观察、分析实验现象,深入理解理解互斥锁的原理及特点掌握在POSIX 规范中的互斥函数的功能及使用方法。
二. 设计内容POSIX 规范中的互斥函数,实现加锁解锁
4)信号量机制的方法,实现进程的加锁解锁,且不产生死锁
概要设计
详细设计
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.异常测试数据及运行结果
六.调试情况,设计技巧及体会
1.改进方案
2.体会
#include stdio.h
#include sys/types.h
#include unistd.h
#include signal.h
#include ctype.h
#includesignal.h
#define MAX_CHILD_NUMBER 10
#define SLEEP_INTERVAL 2
int proc_number=0;
void do_something();
main(int argc, char* argv[])
{ printf(proc_num=%p\n,proc_number);
int child_proc_number = MAX_C
您可能关注的文档
- google身验证器原理与应用.doc
- GS公司绩效考绩效考核论文范文2.doc
- HIV抗体筛查告.doc
- ISO质量管理系289个审核案例.doc
- ISO质量管理系审核案例.doc
- Izuo创业学队调研报告.doc
- izu医院考核效指标tvv.doc
- JSLT-WIKF-002 顾客满意度调查作业指引.doc
- KFC(环境影评估报告).doc
- KPI绩效考核度手册.doc
- 游戏化教学在2025年儿童教育中的应用前景与挑战报告.docx
- 游戏化教学在儿童教育中的应用现状与未来趋势报告.docx
- 深度解读:2025年个人养老金制度创新对金融投资市场的影响分析报告.docx
- 游戏化教学在2025年儿童教育中的实践探索与成效分析.docx
- 深海矿产勘探2025技术专利布局与知识产权保护报告.docx
- 游戏化教学在儿童教育中的个性化辅导策略研究报告.docx
- 游戏化学习在2025年儿童问题解决能力教育中的应用与实践.docx
- 游戏化学习模式在儿童教育中的应用研究报告.docx
- 游戏化学习工具在2025年儿童教育中的创新应用研究报告.docx
- 游戏化教学在儿童教育中的应用与推广策略研究探讨.docx
文档评论(0)