战点 2024-05-09 16:30 采纳率: 17.4%
浏览 10

请补全下面的代码并编译运行

定义了进程控制块pcb数据结构。文件中SJF()函数需要由学生来实现,由于running()函数同样每次都执行ready指针指向的进程,需要做的是将不断创建的进程按照其运行时间正确插入已按运行时间由小到大排列的队列中。请补全下面的代码并编译运行。


 void SJF()//Shortest Job First  不可抢占 
  {
      PCB *tp,*tempp;
    if(!ready ){  //就绪队列为空 
        //待补全  将进程控制块插入空就绪队列,设置首尾指针、运行状态
        
    }
    else{
        tp=ready;
        tempp=tp;
        if(ready->oncerun == 1) //当前进程正在执行 
            tp = tp->link;
        if(tp!=NOTHING) 
        {
            while(p->ntime >= tp->ntime ){//tp为插入位置 
                tempp = tp;            
                tp = tp->link;
                if(tp==NOTHING)
                    break;
            }
        }        
        if(tp == ready){
            if(ready->oncerun == 0){
//插入进程p为当前运行时间最短进程,插入头当前无运行进程并设置插入进程为运行进程
                //待补全  
                
            }
            else{ //当前有运行进程
                //待补全

注意:本次实验希望学生实现的是非抢占的SJF调度,因此你需要注意在新插入进程的时候队首是否已经处于运行状态,再将其插入争取的位置。

  • 写回答

3条回答 默认 最新

  • 专家-皆知 2024-05-09 16:30
    关注

    引自免费微信小程序:皆我百晓生

    你需要实现SJF()函数,根据进程的运行时间对就绪队列进行排序,然后选择运行时间最短的进程调度。确保running()每次执行的是当前就绪队列中运行时间最短的进程。

    评论

报告相同问题?

问题事件

  • 创建了问题 5月9日

悬赏问题

  • ¥15 CCF-CSP 2023 第三题 解压缩(50%)
  • ¥30 comfyui openpose报错
  • ¥20 Wpf Datarid单元格闪烁效果的实现
  • ¥15 图像分割、图像边缘提取
  • ¥15 sqlserver执行存储过程报错
  • ¥100 nuxt、uniapp、ruoyi-vue 相关发布问题
  • ¥15 浮窗和全屏应用同时存在,全屏应用输入法无法弹出
  • ¥100 matlab2009 32位一直初始化
  • ¥15 Expected type 'str | PathLike[str]…… bytes' instead
  • ¥15 三极管电路求解,已知电阻电压和三级关放大倍数