- 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)创建一个进程,父子进程 相互交替执行,输出子进程号和进程ID2)创建三个线程,输出三个线程运行的次数和当前主线程运行次数以及三个线程次数和。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.异常测试数据及运行结果死锁:六.调试情况,设计技巧及体会1.改进方案1)POSIX 规范中fork和kill都是有返回值的,为了程序更加严谨,应该在kill命令也使用接受返回值,如果返回值为-1,则退出。2)程序退出时候使用了return(),但是书上介
您可能关注的文档
最近下载
- 个人开通天然气委托书范本 .pdf VIP
- 2025-2026学年人教版(2024)小学体育与健康二年级(全一册)教学设计(附教材目录).docx
- MG-WD系列采煤机说明书.doc
- 2025年河南省高考物理试卷(含答案解析).docx
- 学堂在线网课《生活英语读写》课后作业单元考核答案.docx VIP
- 2025年第42届全国中学生物理竞赛预赛试题(学生版+解析版) .pdf VIP
- 安全牛:API安全技术应用指南(2024版).pdf VIP
- 2024年浙江省中考统考科学试卷试题真题(含答案解析).pdf VIP
- 《吴门验方》学习笔记.docx VIP
- 新目标大学英语-《综合教学教程》第四册(WELearn答案解析).DOC VIP
文档评论(0)