青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

我要啦免费统计
實驗室老是中毒,今天差點連代碼都保不住了
貼貼備份
進程調度 實驗一 RR 時間片輪轉


#include
<stdio.h>
#include
<stdlib.h>
#include
<conio.h>
#include
<iostream>
using namespace std;

#define getch(type)(type*)malloc(sizeof(type))
#define null 0
#define MAXN 1000
int stack[MAXN];
int top;

struct pcb{//調用進程模塊
    char name[10];//進程名
    char state; //進程狀態: 就緒,運行,完成
    int super; //進程優先級
    int ntime;//需要運行的時間
    int rtime;//到達時間 change
    struct pcb* link;//鏈接指針
}
*ready=null,*p;
typedef 
struct pcb PCB;
void destroy();
void check();

void sort()//建立對進程優先級排列函數
{
   PCB 
*first,*second;
   
   
int insert = 0;
   
   
if( ( ready == null ) || ( ( p -> rtime ) < ( ready -> rtime ) ) ){//優先級最大者,插入隊首
        p -> link = ready;
        ready 
= p;
   }
 
   
else {//進程比較優先級。插入適當的位置中
       first = ready;
       second 
= first -> link;
       
while( second != null){
           
if( (p -> rtime ) < (second -> rtime)){//come ing time
           
//插入當前進程前面
               p -> link = second;
               first 
-> link = p;
               second 
= null;
               insert 
= 1;   
            
               }

            
else{
                 first 
= first -> link;
                 second 
= second -> link;
               }

           
        }

       
if( insert == 0) first -> link =p;

   
   }

   
return ;
}


PCB 
*q;
PCB 
*front,*rear;

void RR()
{
    
int time=0;
    q
=ready;
    front
=ready;
    rear 
=ready;
    
while(rear->link != null) rear= rear -> link; 
    
    
while( front){
        printf(
"Running Time : %d\n",++time);

        
if(front -> rtime <= time){
           
             front 
-> state ='R';

            front 
-> ntime--;//need time minus 1

            printf(
"\n *** 當前正在運行的進程:%s\n",front->name);

            
if( front -> ntime == 0){// the one which is finished
            p = front;

            
if(front -> link !=null )
            front 
=front ->link;
            
else {printf("\n finished\n");break;}


            p 
-> link = null;

            destroy();

            }

            
else{//else unfinished ,connect last

            rear 
-> link = front;

            p
=front;
            
if(front -> link !=null )
            front 
=front ->link;
            
else {printf("\n finished\n");break;}

            p 
-> link = null
            }

        
         check();
//display all pcbs in queue
       }

     
    }

    
return ;
}


void input()
{
    
int i,num;
    system(
"cls");
    
//clrscr();
    printf("\n 請輸入進程數量");
    scanf(
"%d",&num);
    
for( i = 0;i < num; i++){
      printf(
" 進程號No.%d",i);
      p
=getch(PCB);
      printf(
"\n 輸入進程名:");
      scanf(
"%s",p->name);
      printf(
"\n 到達時間:");
      scanf(
"%d",&p->rtime);
      printf(
"\n 輸入進程運行時間:");
      scanf(
"%d",&p->ntime);
      printf(
"\n");
      p 
-> super =0; p -> state='W';
      p 
-> link = null;
      sort();
//調用函數
    }

//    check();
    return;
}


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 ntime \t rtime\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");
 
return ;
}

void check()//建立進程查看函數
{
//    PCB *pr;
   /*    printf("\n *** 當前正在運行的進程:%s",p->name);顯示當前 運行 進程
    disp(p);
*/

    p
=front;
    printf(
"\n ****當前就緒隊列狀態:%c",p->state);/* 顯示隊列狀態 */ 
    
while( p != null){
     disp(p);
     p
=p->link;
    }

    
return ;
}


void destroy()/*建立進程撤銷 函數 (進程 運行結束,撤銷進程)*/
{
    printf(
"\n 進程[%s]已完成。\n",p->name);
    free(p);
    
return;
}


/*void running()//進程就緒函數
{
    (p->rtime)++;
    if( p-> rtime == p -> ntime)// 
        destroy();
    else{
      (p->super)--;
      
      p->state = 'W';
      
      sort();
    }
    return;
}
*/

int main()
{
   freopen(
"in.txt","r",stdin);
    
int len,h=0;
//    char ch;
    input();
    len
=space();
    RR();
/*    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();
        // system("pause");
        printf("\n 按任意鍵繼續.");
        ch=getchar();
        
    }
*/

    printf(
"\n\n進程已經完成。\n");

    
    system(
"pause");
    
return 0;
}

posted on 2008-11-05 20:43 閱讀(4282) 評論(5)  編輯 收藏 引用

評論:
# re: 進程調度 實驗一 RR 時間片輪轉算法 (記錄)[未登錄] 2008-11-06 09:26 | raof01
標題很吸引人,內容很讓人失望。  回復  更多評論
  
# re: 進程調度 實驗一 RR 時間片輪轉算法 (記錄) 2008-11-06 10:01 | PDF閱讀器下載
個人覺得代碼還是不錯的  回復  更多評論
  
# re: 進程調度 實驗一 RR 時間片輪轉算法 (記錄)[未登錄] 2008-11-06 19:58 | cdy20
為了應付 老師堂上檢查
不過要怎么改都行的 ,畢竟模擬

沒有實現 搶占式 也沒有實現多級的
有什么想法都可以 交流  回復  更多評論
  
# re: 進程調度 實驗一 RR 時間片輪轉算法 (記錄) 2008-11-12 13:15 | 飄過
用最小堆做個多優先級的也是個不錯的選擇,不必非用鏈表,怪麻煩的  回復  更多評論
  
# re: 進程調度 實驗一 RR 時間片輪轉算法 (記錄) 2008-11-12 20:54 | cdy20
@飄過
也是

當練手的,兩年沒用過指針了。  回復  更多評論
  

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            精品成人国产| 国产日韩欧美日韩| 免费观看成人| 国产欧美日韩综合| 久久深夜福利免费观看| 久久国产视频网站| 亚洲国产成人精品女人久久久 | 亚洲国产免费看| 欧美激情精品久久久久久黑人| 欧美日韩午夜精品| 欧美一区二区高清| 久久久久久久久久久久久久一区| 亚洲区一区二区三区| 99精品99| 欧美freesex交免费视频| 亚洲欧美日韩在线播放| 久久不射电影网| 日韩午夜高潮| 亚洲欧美日韩网| 亚洲国产精品悠悠久久琪琪| 99国产精品久久| 欧美日韩在线另类| 欧美在线视频免费播放| 欧美成人精品三级在线观看 | 欧美在线视频日韩| 日韩小视频在线观看专区| 亚洲欧美激情视频在线观看一区二区三区| 国产资源精品在线观看| 亚洲三级电影全部在线观看高清| 欧美午夜剧场| 亚洲黄色高清| 国内揄拍国内精品少妇国语| 亚洲精品一区二| 一区二区亚洲精品| 亚洲免费成人av| 精品电影一区| 亚洲欧美另类久久久精品2019| 国产精品99久久久久久有的能看| 久久国产日韩| 小黄鸭精品aⅴ导航网站入口| 免费成人高清视频| 亚洲精品国精品久久99热| 中文一区二区在线观看| 91久久精品日日躁夜夜躁国产| 中文亚洲免费| 亚洲午夜性刺激影院| 免费黄网站欧美| 亚洲图片欧洲图片日韩av| 亚洲尤物视频网| 欧美日韩亚洲视频一区| 美女性感视频久久久| 亚洲一区二区免费看| 欧美v国产在线一区二区三区| 久久天天躁夜夜躁狠狠躁2022 | 欧美亚州韩日在线看免费版国语版| 欧美丝袜第一区| 久久久久久夜| 欧美一区二区三区另类 | 久久综合九色九九| 欧美亚洲视频在线观看| 在线观看中文字幕不卡| 亚洲三级观看| 99re热这里只有精品免费视频| 欧美激情一区二区三区| 欧美一区二区高清在线观看| 一区二区欧美在线观看| 久久视频在线视频| 国产精品视频观看| 久久免费国产精品1| 免费观看一级特黄欧美大片| 欧美搞黄网站| 久久国产福利国产秒拍| 欧美天天视频| 日韩亚洲欧美综合| 亚洲午夜精品久久久久久浪潮 | 亚洲免费观看视频| 亚洲国产激情| 亚洲经典三级| 99这里只有精品| 99综合视频| 国产精品福利影院| 亚洲欧美久久久久一区二区三区| 午夜精品理论片| 国产综合色在线| 久久婷婷丁香| 亚洲国产日韩一区| 伊人精品视频| 欧美大成色www永久网站婷| 亚洲片在线资源| 在线一区二区三区四区| 一区二区免费在线播放| 国产女人精品视频| 久久免费视频网站| 亚洲欧洲偷拍精品| 性久久久久久久久久久久| 亚洲欧美日韩一区二区在线 | 亚洲国产成人久久综合一区| 夜夜嗨av一区二区三区免费区| 亚洲精品久久久久久久久久久| 亚洲一区二区三区免费在线观看| 激情综合视频| 亚洲精品一区久久久久久| 国产精品每日更新| 亚洲午夜在线观看视频在线| 欧美va亚洲va国产综合| 国产日韩欧美不卡在线| 亚洲精品之草原avav久久| 欧美日韩国产色视频| 欧美午夜在线一二页| 国产欧美日韩在线观看| 欧美一区二区三区喷汁尤物| 久久精品国产久精国产一老狼| 亚洲一区二区三区视频播放| 欧美精品二区| 亚洲国产日韩一区| 久久综合色综合88| 亚洲国内自拍| 亚洲欧美综合一区| 亚洲第一在线综合在线| 欧美久久久久久久久久| 先锋影音网一区二区| 亚洲高清不卡一区| 羞羞视频在线观看欧美| 亚洲人成网站在线观看播放| 国产精品久久久久天堂| 欧美国产激情二区三区| 欧美在线视频二区| 国产精品久久久久久五月尺| 国产精品久久久久久福利一牛影视 | 国产模特精品视频久久久久| 最新国产成人av网站网址麻豆| 亚洲国产天堂久久综合网| 麻豆国产精品一区二区三区| 亚洲第一黄色| 一区二区成人精品| 欧美日韩一区二区三区在线观看免| 99视频在线精品国自产拍免费观看 | 国产精品视频xxx| 欧美一区二区三区四区视频| 久久中文字幕导航| 亚洲精品1234| 国产欧美日韩在线| 激情综合久久| 久久精品一本久久99精品| 亚洲人成绝费网站色www| 欧美一级久久| 亚洲欧美精品在线观看| 国产精品日韩欧美一区二区三区| 一区二区三区欧美视频| 欧美在线不卡视频| 亚洲欧美日韩国产成人| 亚洲欧美日本日韩| 欧美一区二区精品久久911| 亚洲欧美在线视频观看| 午夜欧美大片免费观看 | 国产日韩一区在线| 国产一区二区黄色| 在线观看中文字幕不卡| 亚洲黄色一区二区三区| 日韩网站在线观看| 亚洲在线电影| 久久精品国产精品亚洲综合| 六月丁香综合| 亚洲三级视频| 亚洲视频免费| 久久精品视频播放| 免费亚洲电影在线| 欧美三级网页| 国产精品自拍一区| 一区二区视频欧美| 一区二区三区欧美亚洲| 欧美一区午夜视频在线观看| 久久综合影视| 日韩亚洲欧美一区| 久久成人18免费观看| 美女黄色成人网| av成人免费在线| 欧美福利网址| 国产精品h在线观看| 国产欧美一区二区精品婷婷| 在线观看日韩www视频免费| 夜色激情一区二区| 午夜精品一区二区三区四区| 久色成人在线| 一本色道久久综合亚洲精品高清| 国产精品综合网站| 噜噜噜久久亚洲精品国产品小说| 美女精品国产| 99精品欧美一区二区三区| 久久av红桃一区二区小说| 欧美国产欧美亚州国产日韩mv天天看完整| 欧美三级特黄| 亚洲国产另类久久精品| 性欧美暴力猛交69hd| 欧美黄色精品| 欧美一级片一区| 欧美日韩视频在线一区二区 | 亚洲国产第一页| 亚洲一二三区在线| 欧美黄色影院|