- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
过程调剂2
进程调度2
#include stdio.h
#include stdlib.h
#include string.h
#include ctype.h
#define IN 1 /* 进入就绪队列 */
#define OUT 0 /* 出就绪队列 */
/*进程是程序在处理机上执行过程,进程存在的标识是进程控制块(PCB),所以应首先设计
进程控制块的结构(struct)*/
typedef struct {
char name[10];/* 进程标识符 */
int prio; /* 进程优先数 */
int round; /* 进程时间轮转片 */
int cputime; /* 进程应用CPU的时间 */
int needtime;/* 进程运行需要的时间 */
int count; /* 计数器 */
char state; /* 进程的状态 */
struct node *next;/* 链指针 */
}PCB;
void firstin(void);
void prt1(char a);
void prt2(char a,PCB *q);
void prt(char algo);
void insert1(PCB *q);
void insert2(PCB *p2);
void creat1(char alg);
void creat2(char alg);
void priority(char alg);/* 优先调度算法的执行函数 */
void roundrun(char alg);/* 时间片轮转算法的执行函数 */
int N; /* 进程数,设为全局变量 */
PCB *finish,*ready,*tail,*run;/* finish,ready,run分别为完成队列指针,就绪队列指针 */
/* tail为循环轮转中就绪队列的指针 */
void main()
{
char algo;
clrscr();
printf(type the algorithm P/R(priority/roundrobin)\n);
scanf(%c,algo);
printf(Enter process number\n);
scanf(%d,N);
if(algo==P||algo==p)
{
creat1(algo);
priority(algo);
}
else
if(algo==R||algo==r)
{
creat2(algo);
roundrun(algo);
}
getch();
}
/*将就绪队列的第一个进程投入运行*/
void firstin()
{
run=ready; /* 就绪队列头指针赋值给运行头指针 */
run-state=R; /* 进程状态变为运行态 */
ready=ready-next; /* 就绪队列头指针后移到下一个进程 */
}
/*标题输出函数*/
void prt1(char a)
{
if(toupper(a)==P)
printf(name cputime needtime priority state\n);
else
printf(name cputime needtime roundrun state\n);
}
/*进程PCB的输出*/
void prt2(char a,PCB *q)
{
if(toupper(a)==P) /* 优先数法输出 */
printf(%-10s%-10d%-10d%-10d%c\n,q-name,q-cputime,
q-n
文档评论(0)