基本信息
源码名称:Linux优先级时间片调度C++源码
源码大小:4.28KB
文件格式:.cpp
开发语言:C/C++
更新时间:2017-11-03
   友情提示:(无需注册或充值,赞助后即可获取资源下载链接)

     嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300

本次赞助数额为: 4 元 
   源码介绍
Linux进程调度(基于优先级时间片调度算法)

int time()
{
    float time_temp=0;
	
    struct task_struct  copy_PCB[MAX][MAX];//备份
    for(int v=1; v<=temp; v  )
    {
		for(int u=1;u<=P[v];u  )
		{
			copy_PCB[v][u]=PCB[v][u];//对进程的初始化信息备份	
		}
    }
	time_temp=PCB[1][1].come_time;
	for(int i=1;i<=temp;i  )
	{
		while (PCB[i][P[i]].run_flag==0)
		{
		for(int j=1;j<=P[i];j  )
		{
			if(PCB[i][j].come_time>time_temp)
            {
                time_temp=PCB[i][j].come_time;
            }
            if(PCB[i][j].run_flag==0)//该进程还未结束
            {
                if(PCB[i][j].start_flag==0)  //该条件成立则说明,该进程是第一次执行,记录开始执行时间
                {
                    PCB[i][j].run_begin_time=time_temp;
                    PCB[i][j].start_flag=1;
                }
                if(PCB[i][j].run_time/time_counter>1)//至少有两倍的时间片未执行
                {
                    PCB[i][j].run_time=PCB[i][j].run_time-time_counter;
                    time_temp=time_temp time_counter;
                }
                else if(PCB[i][j].run_time-time_counter==0)
                {
                    time_temp=time_temp time_counter;
                    PCB[i][j].run_end_time=time_temp;
                    PCB[i][j].run_flag=1;
                    PCB[i][j].run_time=copy_PCB[i][j].run_time;
                }
                else//仅剩下不足一倍的时间片
                {
                    time_temp=time_temp PCB[i][j].run_time;
                    PCB[i][j].run_end_time=time_temp;
                    PCB[i][j].run_flag=1;
                    PCB[i][j].run_time=copy_PCB[i][j].run_time;
                }
            }
		}
	}
	}
	return 0;
}