战点 2024-05-09 16:39 采纳率: 17.4%
浏览 0

补全并实现 insert()函数

实现 insert()和rr()函数,前者函数只需要简单的将新创建的进程插入就绪队列,而后者需要你在每次执行running()前将需要执行的正确的进程放在队首,时间片用完的进程放在队尾。现在请根据轮转调度算法的原理补全rr()函数。
//创建就绪队列


void insert()
 {
     PCB *q=NOTHING;
    if(!ready) {
         //待补全
         ready=p;
         ready->state = 'R';
         ready->oncerun=1;
         pfend=p;
         pfend->link = NOTHING;
    }else{
        q=ready; 
        while(q->link){
            q=q->link;
        }
        q->link=p;
        p->state = 'w';
        pfend = p;
        pfend->link = NOTHING;
    }
}
  • 写回答

2条回答 默认 最新

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

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

    为了实现这个功能,你需要维护一个表示就绪队列的数据结构(如列表或链表)。insert()函数只需在队列末尾添加进程,而rr()则需在运行进程后,将其移动到队尾,新调度的进程放队首。具体代码取决于你使用的编程语言和数据结构。

    评论

报告相同问题?

问题事件

  • 创建了问题 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 三极管电路求解,已知电阻电压和三级关放大倍数