版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、年级11级专 业计算机科学与技术班级五班组号 12组实验室9#205日期2014/05/17实验名称 实验二、进程控制与通信管理实验内容分项内容实验级别1、Linux 系统常用进程管理命令的使用操作系统观察级2、Linux 系统常用进程创建与管理的系统调用原码阅读与系统编程级3、Windows平台常用进线程控制API原码阅读与系统编程级4、进程同步与互斥控制(读者写者、一家人吃苹果桔子、哲学家吃饭)码阅读与系统编程级5、简单进程通信(管道、消息缓冲、邮件槽等)(原码阅读与系统编程级)小 组 成 员姓名学号组内分工自我评分教师评分独立完成实验二(1) 良好独立完成实验二(2) 良好独立完成实验二
2、(3) 良好独立完成实验二(4) 良好独立完成实验二(5) 良好小组成绩评定教师签名: 年 月 日实验分项11、Linux 系统常用进程管理命令的使用 2、Linux 系统常用进程创建与管理的系统调用 3、Windows平台常用进线程控制API 4、进程同步与互斥控制 5、简单进程通信实验目的一、实验目的:l1、加深对进程概念的理解,明确进程和程序的区别。l2、进一步认识并发执行的实质。l3、分析进程争用资源的现象,学习解决进程互斥的方法。实验要求具体题目:进程创建、进程控制系统平台:Linux/Windows操作系统实验原理步骤(算法流程)2、 实验原理1 Linux 系统常用进程管理命令(
3、1)at命令:定时运行命令 让系统在两天后的17:30执行文件data中指定的作业,使用命令: at f data 15:30 +2 days(2)bg命令后台运行命令 如果要将一个大目录的文件进行排序后,将结果输入到一个文件中,可以使用命令: du -a / | sort -rn /tmp/du.sorted (3)Fg挂起程序 使用fg命令时,要加入后台任务号码,如果不加任何号码,则所变动的均是当前任 务。 du -a / | sort -rn /tmp/du.sorted &1 237 #fg 1 (4) Jobs显示后台程序 先把两个进程放在系统后台运行,然后使用jobs命令查看后台任
4、务的执行情况:du -a /etc user.data &1 233# find / -name core -type f -ls core.data &2 234#jobs -l1 + 237 Running du -a /etc user.data2 - 238 Running find / -name core -type f -ls core.data (5)kill命令杀掉进程 命令执行过程如果出错,用户可用kill来结束任务。对于在后台运行的进程, 可以使用kill命令终止: du -a / | sort -rn /tmp/du.sorted & 1 237 #kill 237 (
5、6)nice命令改变权限优先级 将ls命令的优先序加1并执行,将结果输入文件1.txt: nice -n 1 ls 1.txt (7)renice命令修改优先级 将进程PID为987及32的进程与进程拥有者为daemon及root的优先级别号加1: renice +1 987 -u daemon root -p 32 (8)sleep命令暂停进程 下面的命令使进程先暂停60秒,然后查看哪个用户登录到系统中: sleep 60; who2、进程同步与互斥控制(数据同步),原理如下: (1)、设置全局变量:int ticket=100;互斥量:HANDLE hMutex; (2)、创建互斥信号量t
6、icket:hMutex=CreateMutex(NULL,TRUE,ticket); (3)、用WaitForSingleObject(hMutex,INFINITE);捕获互斥信号量hMutex (4)、用ReleaseMutex(hMutex);释放互斥量的使用权3、通过邮件槽实现简单进程通信,原理如下: (1)、油槽服务器: 1)hMailslot=CreateMailslot(.mailslotMyMailslot,0, MAILSLOT_WAIT_FOREVER,NULL);/创建一个邮路。 2)ReadFile(hMailslot,buf,100,&dwRead,NULL);/读
7、取邮路数据 3)CloseHandle(hMailslot);/关闭油槽 (2)、油槽客户端: 1)hMailslot=CreateFile(.mailslotMyMailslot,GENERIC_WRITE, FILE_SHARE_READ,NULL,OPEN_EXISTING,FILE_ATTRIBUTE_NORMAL,NULL); /创建油槽文件 2)WriteFile(hMailslot,buf,strlen(buf)+1,&dwWrite,NULL);/写入数据 3)CloseHandle(hMailslot);/关闭油槽实验源代码如下:1、 进程同步与互斥控制(数据同步):#inc
8、lude stdafx.h#include#includeiostreamusing namespace std;int index =0;int ticket=100;HANDLE hMutex;DWORD WINAPI Fun1Proc(LPVOID lpParameter)while(TRUE)WaitForSingleObject(hMutex,INFINITE);if(ticket0)coutthread1 sell ticket :ticket-0)coutthread2 sell ticket :ticket-endl;elsebreak;ReleaseMutex(hMutex)
9、;return 0;int _tmain(int argc, _TCHAR* argv)HANDLE hTread1;HANDLE hTread2;hTread1=CreateThread(NULL,0,Fun1Proc,NULL,0,NULL);hTread2=CreateThread(NULL,0,Fun2Proc,NULL,0,NULL);CloseHandle(hTread1);CloseHandle(hTread2);hMutex=CreateMutex(NULL,TRUE,ticket);if(hMutex)if(ERROR_ALREADY_EXISTS=GetLastError(
10、)coutOnly one instance can run!endl;return 0;ReleaseMutex(hMutex);ReleaseMutex(hMutex);Sleep(10000);return 0;2、 邮件槽进程通信:1) 油槽服务器:(关键代码段)void C油槽客户端Dlg:OnSend()/ TODO: 在此添加控件通知处理程序代码HANDLE hMailslot;hMailslot=CreateFile(.mailslotMyMailslot,GENERIC_WRITE,FILE_SHARE_READ,NULL,OPEN_EXISTING,FILE_ATTRIBU
11、TE_NORMAL,NULL);if(INVALID_HANDLE_VALUE=hMailslot)MessageBox(打开油槽失败!);return;CString str;char buf100;m_edit.GetWindowText(str);strcpy_s(buf,str);DWORD dwWrite;if(!WriteFile(hMailslot,buf,strlen(buf)+1,&dwWrite,NULL)MessageBox(写入数据失败!);CloseHandle(hMailslot);return;CloseHandle(hMailslot);2) 油槽客户端:(关键
12、代码段)void C油槽客户端Dlg:OnSend()/ TODO: 在此添加控件通知处理程序代码HANDLE hMailslot;hMailslot=CreateFile(.mailslotMyMailslot,GENERIC_WRITE,FILE_SHARE_READ,NULL,OPEN_EXISTING,FILE_ATTRIBUTE_NORMAL,NULL);if(INVALID_HANDLE_VALUE=hMailslot)MessageBox(打开油槽失败!);return;CString str;char buf100;m_edit.GetWindowText(str);strcp
13、y_s(buf,str);DWORD dwWrite;if(!WriteFile(hMailslot,buf,strlen(buf)+1,&dwWrite,NULL)MessageBox(写入数据失败!);CloseHandle(hMailslot);return;CloseHandle(hMailslot);(写不完时,可另加附页。)实验结果及分析三、实验结果:1、实验截图:2-1进程控制达到数据同步处理截图2-2 油槽通信控制面板截图2-3 油槽-服务器截图2-4 油槽-客户端截图2-5 发送-接受效果截图2、 结果分析: 1)、ls 命令列出了指定目录下的文件名和目录名,参数-l要求显示
14、文件或目录的详 细信息,例如类型、访问权限、连接数、拥有者等。 在Linux中,用户通过利用fork创建的进程来与原进程运行相同的程序代码,为了 使新进程运行新的程序,用户可以使用系统调用exec来装入一个新的程序到当前进 程的地址空间,如果exec调用成功,系统开始执行新程序,永远不会返回原来的程 序。 2)、进程同步与互斥控制,能有效的控制全局变量在某一进程执行过程中唯一被访 问。在多线程程序中容易出现共享资源因时间片到期而终止访问,这样就很容易出 现数据的错乱。假如全局变量未火车票;对于线程函数(FunProc1、FunProc2),在 访问全局变量ticket时,ticket自减一。如
15、果在线程函数1(FunProc1)访问ticket, 还没有来得及自减一就因时间片到期而被线程函数2(FunProc2)抢占访问,然后 自减一。这样就造成了资源数据不一致,从而产生很危险的后果。 本实验通过设置互斥信号量从而达到线程之间对共享资源的同步访问,以此还可以 实现进程同步中的读者/写者问题。 3)、由于油槽是单向通信机制,所以只能通过创建油槽服务器进程读取数据,打开 油槽客户端进程写入数据。如果只打开油槽服务器,创建读取数据进程而没有打开 客户端就会导致服务器进入无限等代状态,造成程序崩溃。 在创建进程句柄后要记得释放句柄,不然会产生不良后果。心得体会 在了解了操作系统中进程间的通信的方式我们使用了邮槽实现了
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 企业市场推广团队建设方案
- 企业全渠道用户体验优化方案
- 2026贵州黔东恒贵工业经济发展(集团)有限责任公司市场化选招副总经理1人建设考试参考试题及答案解析
- 企业品牌传播渠道设计方案
- 企业客户满意度提升计划
- 2026广东中山市港口污水处理有限公司招聘合同制工作人员8人建设考试备考试题及答案解析
- 企业产品上市推广活动策划方案
- 2025年县乡教师选调考试《教育学》试题附参考答案详解(培优b卷)
- 2026四川省农业科学院水产研究所(四川省水产研究所) 科研助理招聘2人建设笔试备考题库及答案解析
- 2026年度春季江铜集团贸易事业部校园招聘2人建设考试备考题库及答案解析
- 2026高考蓝皮书高考关键能力培养与应用第1节 3.组织与运用
- 2025年智联招聘国企笔试题库及答案
- 2025年康复治疗师资格考试历年真题及解析
- 车间主任转正述职报告
- 老年人截肢术护理
- 再生资源公司介绍
- 输液科静脉输液操作规范
- 上海某高校学生心理健康事件应急干预与支持办法
- 质量成本培训课件
- 2025广东广州市黄埔区文冲街招聘垃圾分类督导员和垃圾分类专管员3人备考练习题库及答案解析
- GB/T 18226-2025公路交通工程钢构件防腐技术条件
评论
0/150
提交评论