【操作系统】进程管理

总结

进程管理导图

进程

1.组成&特点

进程(进程映像:PCB,程序,数据)是资源分配和调度的独立单位。(动态的,而非静态)
PCB: 包含进程的标记,优先级。
正文段: 全局赋值变量。
堆段: malloc动态分配资源。
栈段: 未赋值局部变量,函数调用实参传递。
 

2.七状态&四变化

7状态,4变化
若就绪态有就绪进程,则运行态必有进程。没有运行进程和就绪进程不代表没有进程:可能死锁,可能等待。

3.控制操作

对于键盘数据输入开启单线程即可。
 

4.进程通信

因为每个进程都有独立的空间,需要借助 kernel 通信。
共享存储: 数据结构,数据区。
消息传递: 直接通信(消息队列);间接通信(挂入中间实体)。
管道通信: 双向传输的半双工通信的pipe文件操作;管道空,读进程阻塞;管道满,写进程阻塞,允许同时存在。
 
 

线程

1.特点

基本: 进程实体,独立调度和分派的最小单位;处理机的分配单元。
其他: 不拥有资源,并发性强,开销小,共享同一进程下的资源,可以直接通信;同一程序可分成不同的用户线程供用户使用。
 

2.实现

ULT & KLT: 用户,内核。
多线程模型: 多对一(不同参数控制同一个程序),一对一(进程<->程序),多对多(并发执行不同程序),一对多(一个进程多个程序)。
多任务模型: OS同时执行的程序个数。
 
 

处理机调度

1.调度层次

(高级调度)作业调度:
(中级调度)内存调度:
(低级调度)进程调度:
 

2.调度方式&性能指标

调度方式:抢占/非抢占。
(常考)周转时间: 完成时间 - 进入队列的时间
(常考)带权周转时间: 周转时间 / 程序执行时间
RR的最后的周转时间以最后的那个为准。
 

3.(常考)调度方法

操作指标具体细节
FCFS时间不可剥夺,短不利,CPU长
SJF执行时间长度长不利,饥饿
优先级调度优先级优先级一致的时候,先来先服务
高响应比(等待 + 要求服务时间) / 要求服务时间,高者优先
RR时间片大小强行停止,每次-1
多级反馈适合各类用户

 
 

进程同步

1.同步

制约关系。
 

2.临界区互斥

空闲让进,忙则等待,有限等待,让权等待。

软件实现

单标志法:
设置公共资源占用标记turn,如果 turn 为一个标记为0的时候,这个程序可以使用。

while(turn != 0);     |    while(turn != 1);
critical section;	  |    critical section;
turn = 1;             |    turn = 0;
remainder section;    |    remainder section;                                                

 
双标志检查法
先检测对方的标志位,然后再检查自己的标志位。

//P0
while(flag[j]);  //P2访问的话挡在外面
flag[i] =  true;
critical section;
	flag[i] = false;
remainder section;

//P1
while(flag[i]);	//P1访问的话挡在外面
flag[j] = true;
critical section;
	flagp[j] = false;
remainder section;

 
双标志法后检查
先设置自己的标志位,然后再检测对方的标志。

//P1
flag[i] = true;
while(flag[j]);
critical section;
	flag[i] = false;
remainder section;

//P2
flag[j] = true;
while(flag[i]);
critcial section;
	flag[j] = false;
remainder section;

 
Peterson’s Algorithm
设置完自己的标志之后也补充一个turn设置为对方使用。

//P1
flag[i] = true;
turn = j;
while(flag[j] && turn == j);	//P2要使用,谦让之后挡在门外
critical section;
	flag[i] = section;
remainder section;

//P2
flag[j] = true;
turn = i;
while(flag[i] && turn == i);
critical section;
	flag[j] =  false;
remainder section;

 

硬件实现

中断屏蔽: 关/开中断
硬件指令: T&S , Swap
 

信号量 & 前驱关系实现

PV: wait(消耗一个资源),signal(产生一个资源)
前驱实现

semaphore a1 = a2 = a3 = a4 = 0;	//每种关系产生 / 消耗一个资源
S1(){
	V(a1);V(a2);
}

管程: 一个数据结构和能为并发进程所执行的一组操作,这组操作能同步进程和改变管程中的数据。

 

3.(常考)经典设计问题

关系分析
整理思路
信号量设置
生产者消费者

关系: 生产者 + 消费者
思路: 生产者生产放入缓冲池,消费者从缓冲池中拿出资源;缓冲池要设置满和空。
信号: mutex,full

semaphore mutex = 1 , empty = n , full = 0;
producer(){
	while(1){
		produce an item in nextp;
		P(empty);
			P(mutex);
				add an item in nextp;
			V(mutex);
		V(full);
	}
}

consumer(){
	while(1){
		P(full);
			P(mutex);
				remove an item from buffer; 
			P(mutex);
		V(empty);
		consume the item;
	}
}

 

2.读者写者

关系: 读者,写者
思路: 1.多个读者同时读取信息,2.一个写者写入信息,3.写完成之前不允许其他读者/写着工作;4.写前,读者/写者退出。
信号: mutex,cnt(此时读取资源的人数),rw(控制cnt的信号)

semaphore mutex = 1 , rw = 1;
int cnt = 0;
Reader(){
	while(1){
		P(rw);
			Writing;
		V(rw);
	}
}
Writer(){
	while(1){
		P(mutex);
			if(count == 0)	P(rw);
			count ++;
		V(mutex);
		
		reading;
		
		P(mutex);		
			count --;
			if(count == 0)	V(rw);
		V(mutex);
	}
}

 

3.哲学家进餐问题

关系: 哲学家和其两边的哲学家存在互斥关系。
思路: 取筷子的时候要带上互斥量,拿起筷子,吃,放下筷子,思考。
信号: chop[5] = {1 , 1 , 1 , 1 , 1} , 左边标号 i,右边标号(i + 1) % 5;mutex。

semaphore chop[5] = {1 , 1 , 1 , 1 , 1} , mutex = 1;
Pi(){
	do{
		P(mutex);
			P(chop[i]);	//拿左筷子
			P(chop[(i + 1) % 5]);	//拿右筷子
		V(mutex);
		eat;
		V(chop[i]);	//放左筷子
		V(chop[(i + 1) % 5]);	//放右筷子
		think;
	}while(1);
}

 

4.吸烟者问题

关系: 三个抽烟者,一个供应者
思路: 一个随机生成函数,三个进程函数。
信号: offer1, offer2 , offer3 , finish抽烟动作。

int random;
semaphore offer1 = offer2 = offer3 = finish = 0;

process P1(){
	random;
	random = random % 3;
	if(random == 0)	V(offer1);
	else if(random == 1) V(offer2);
	else V(offer3);
	put on the desk;
	P(finish);
}

Process P2(){
	while(1){
		P(offer3);
			put paper and clue on the desk;
		V(finish);
	}
}

Process P3(){
	while(1){
		P(offer2);
			put cig and clue on the desk;
		V(finish);
	}
}

Process P4(){
	while(1){
		P(offer1);
			put cig and paper on the desk;
		V(finish);
	}
}
实验目的 设计一个有 N个进程并行的进程调度程序。采用最高优先级优先的调度算法进行进程调度的模拟。 实验要求 设计一个有 N个进程并行的进程调度程序。采用最高优先级优先的调度算法进行进程调度的模拟。 实验原理 每个进程用一个进程控制块( PCB)表示。进程控制块可以包含进程名、优先级、到达时间、需要运行时间、已用CPU时间、进程状态等等。 进程的运行时间以时间片为单位进行计算。 每个进程的状态可以是就绪 W(Wait)、运行R(Run)、或完成F(Finish)三种状态之一。进程名、优先级、需要运行时间通过键盘输入。就绪进程获得 CPU后都只能运行一个时间片。用已占用CPU时间加1来表示。运行一个时间片后,进程的已占用 CPU时间已达到所需要的运行时间,则撤消该进程,否则将进程的优先级减1(即降低一级),然后把它插入就绪队列等待CPU。每进行一次调度程序都打印一次运行进程、就绪队列、以及各个进程的 PCB,以便进行检查。 重复以上过程,直到所有进程都完成为止。 实验仪器 PC及其LINUX操作系统 实验步骤 调度算法的流程图如下 : 实验内容 程序部分: #include "stdio.h" #include #include #define getpch(type) (type*)malloc(sizeof(type)) #define NULL 0 struct pcb { /* 定义进程控制块PCB */ char name[10]; char state; int super; int ntime; int rtime; struct pcb* link; }*ready=NULL,*p; typedef struct pcb PCB; sort() /* 建立对进程进行优先级排列函数*/ { PCB *first, *second; int insert=0; if((ready==NULL)||((p->super)>(ready->super))) /*优先级最大者,插入队首*/ { p->link=ready; ready=p; } else /* 进程比较优先级,插入适当的位置中*/ { first=ready; second=first->link; while(second!=NULL) { if((p->super)>(second->super)) /*若插入进程比当前进程优先数大,*/ { /*插入到当前进程前面*/ p->link=second; first->link=p; second=NULL; insert=1; } else /* 插入进程优先数最低,则插入到队尾*/ { first=first->link; second=second->link; } } if(insert==0) first->link=p; } } void input() /* 建立进程控制块函数*/ { int i,num; //clrscr(); /*清屏*/ printf("\n 请输入进程号?"); scanf("%d",&num;); for(i=0;iname); printf("\n 输入进程优先数:"); scanf("%d",&p->super); printf("\n 输入进程运行时间:"); scanf("%d",&p->ntime); printf("\n"); p->rtime=0;p->state='w'; p->link=NULL; sort(); /* 调用sort函数*/ } } int space() { int l=0; PCB* pr=ready; while(pr!=NULL) { l++; pr=pr->link; } return(l); } void disp(PCB * pr) /*建立进程显示函数,用于显示当前进程*/ { printf("\n qname \t state \t super \t ndtime \t runtime \n"); printf("|%s\t",pr->name); printf("|%c\t",pr->state); printf("|%d\t",pr->super); printf("|%d\t",pr->ntime); printf("|%d\t",pr->rtime); printf("\n"); } void check() /* 建立进程查看函数 */ { PCB* pr; printf("\n **** 当前正在运行的进程是:%s",p->name); /*显示当前运行进程*/ disp(p); pr=ready; printf("\n ****当前就绪队列状态为:\n"); /*显示就绪队列状态*/ while(pr!=NULL) { disp(pr); pr=pr->link; } } void destroy() /*建立进程撤消函数(进程运行结束,撤消进程)*/ { printf("\n 进程 [%s] 已完成.\n",p->name); free(p); } void running() /* 建立进程就绪函数(进程运行时间到,置就绪状态*/ { (p->rtime)++; if(p->rtime==p->ntime) destroy(); /* 调用destroy函数*/ else { (p->super)--; p->state='w'; sort(); /*调用sort函数*/ } } void main() /*主函数*/ { int len,h=0; char ch; input(); len=space(); while((len!=0)&&(ready!=NULL)) { ch=getchar(); h++; printf("\n The execute number:%d \n",h); p=ready; ready=p->link; p->link=NULL; p->state='R'; check(); running(); printf("\n 按任一键继续......"); ch=getchar(); } printf("\n\n 进程已经完成.\n"); ch=getchar(); }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值