- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
操作系统原理
题 目:模拟进程创建、终止、阻塞、唤醒原语
院 (部): 管理工程学院
专 业: 信息管理与信息系统
班 级: 信管131
姓 名: 栾庆一
学 号: 20130216027
实验题目一:模拟进程创建、终止、阻塞、唤醒原语
一、题目类型:必做题目。
二、实验目的:通过设计并调试创建、终止、阻塞、唤醒原语功能,有助于对操作系统中进程控制功能的理解,掌握操作系统模块的设计方法和工作原理。
三、实验环境:
1、硬件:pc机及其兼容机。
2、软件:Windows OS,Turbo C或C++、VC++、VS.net、Java等。
四、实验内容:
1、设计创建、终止、阻塞、唤醒原语功能函数。
2、设计主函数,采用菜单结构(参见后面给出的流程图)。
3、设计“显示队列”函数,目的能将就绪、阻塞队列中的进程信息显示在屏幕上,以供随时查看各队列中进程的变化情况。
五、算法流程图
系统主菜单 1…创建
2…阻塞
3…唤醒
4…终止
5…显示
0…退出
请输入您需要的功能(0-5):
六、程序清单
#include stdio.h
#include string.h
struct pcb
{
char name[10];
int status;
int order;
int time;
int wtime;
int ytime;
}pcb[11];//该结构体用于存储已经输入的进程
struct ghost
{
char name[10];
int status;
int order;
int time;
}ghost[11];//该结构体用于优先级调度时,进程的优先级排序
char a_name[10];
int i=0,y,a=0,x,z,jilu;
void insert();
void block();
void rouse();
void stop();
void outPut();
void control();//实验二添加函数
void order_control();//实验二添加函数
void time_control();//实验二添加函数
void insert()
{
jilu=0;//jilu是一个用于判断的变量,在重复时进行判断跳过
if(i=10)
printf(进程已经存在10个,无法继续添加进程\n);
else
{
printf(请输入插入pcb的数据:\n);
printf(1、进程名:);
scanf(%s,pcb[i].name);
printf(2、该进程的优先级(1-10):);
scanf(%d,pcb[i].order);
printf(3、运行时间);
scanf(%d,pcb[i].time);
for(y=0;yi;y++)
{
if (strcmp(pcb[i].name,pcb[y].name)==0)
{
printf(您输入的进程名已经存在,请重新输入!\n);
jilu=y+1;
}
}
if(jilu0)jilu=0;
else
{
printf(输入已经完成\n您输入的数据为:\n进程名: %s\n优先级: %d\n运行时间: %d\n,pcb[i].name,pcb[i].order,pcb[i].time);
printf(------------------------------------------------------------------\n);
strcpy(ghost[i].name,pcb[i].name);
ghost[i].order=pcb[i].order;
ghost[i].time=pcb[i].time;
pcb[i].status=1;
ghost[i].status=1;
pcb[i].wtime=pcb[i].time;
pcb[i].ytime=0;
i++;
}
}
}
void block()
{
int m;
printf(\n请输入您要改变状态的进程的进程名: );
scanf(%s,a_name);
文档评论(0)