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

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


#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{//調(diào)用進(jìn)程模塊
    char name[10];//進(jìn)程名
    char state; //進(jìn)程狀態(tài): 就緒,運行,完成
    int super; //進(jìn)程優(yōu)先級
    int ntime;//需要運行的時間
    int rtime;//到達(dá)時間 change
    struct pcb* link;//鏈接指針
}
*ready=null,*p;
typedef 
struct pcb PCB;
void destroy();
void check();

void sort()//建立對進(jìn)程優(yōu)先級排列函數(shù)
{
   PCB 
*first,*second;
   
   
int insert = 0;
   
   
if( ( ready == null ) || ( ( p -> rtime ) < ( ready -> rtime ) ) ){//優(yōu)先級最大者,插入隊首
        p -> link = ready;
        ready 
= p;
   }
 
   
else {//進(jìn)程比較優(yōu)先級。插入適當(dāng)?shù)奈恢弥?/span>
       first = ready;
       second 
= first -> link;
       
while( second != null){
           
if( (p -> rtime ) < (second -> rtime)){//come ing time
           
//插入當(dāng)前進(jìn)程前面
               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 *** 當(dāng)前正在運行的進(jì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 請輸入進(jìn)程數(shù)量");
    scanf(
"%d",&num);
    
for( i = 0;i < num; i++){
      printf(
" 進(jìn)程號No.%d",i);
      p
=getch(PCB);
      printf(
"\n 輸入進(jìn)程名:");
      scanf(
"%s",p->name);
      printf(
"\n 到達(dá)時間:");
      scanf(
"%d",&p->rtime);
      printf(
"\n 輸入進(jìn)程運行時間:");
      scanf(
"%d",&p->ntime);
      printf(
"\n");
      p 
-> super =0; p -> state='W';
      p 
-> link = null;
      sort();
//調(diào)用函數(shù)
    }

//    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()//建立進(jìn)程查看函數(shù)
{
//    PCB *pr;
   /*    printf("\n *** 當(dāng)前正在運行的進(jìn)程:%s",p->name);顯示當(dāng)前 運行 進(jìn)程
    disp(p);
*/

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

    
return ;
}


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


/*void running()//進(jìn)程就緒函數(shù)
{
    (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 按任意鍵繼續(xù).");
        ch=getchar();
        
    }
*/

    printf(
"\n\n進(jìn)程已經(jīng)完成。\n");

    
    system(
"pause");
    
return 0;
}

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

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

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

當(dāng)練手的,兩年沒用過指針了。  回復(fù)  更多評論
  

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   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| 亚洲国产精品va| 久久久久一区二区| 最新日韩av| 99re成人精品视频| 国产精品日韩专区| 老司机一区二区| 欧美激情一区三区| 午夜精品福利在线| 久久免费偷拍视频| 99精品热视频只有精品10| aa级大片欧美| 一区二区三区在线免费视频| 亚洲国产精品va在线观看黑人| 欧美色区777第一页| 久久精品亚洲精品| 欧美另类在线观看| 久久国产欧美精品| 欧美精品性视频| 久久精品国产一区二区三| 欧美成人三级在线| 久久精品人人做人人爽电影蜜月| 免费久久99精品国产| 亚洲欧美综合另类中字| 久久综合久久综合九色| 香蕉亚洲视频| 欧美日本一道本| 欧美成人综合一区| 国产欧美一级| 一本色道久久综合| 亚洲高清在线播放| 性8sex亚洲区入口| 亚洲一区二区三区色| 女同一区二区| 久久综合伊人77777| 国产精品久久久久aaaa| 亚洲激情黄色| 亚洲国产欧美久久| 久久成人这里只有精品| 香蕉久久国产| 国产精品久久二区二区| 亚洲国产日韩欧美在线动漫| 狠狠色丁香婷婷综合| 亚洲欧美日产图| 午夜精品久久一牛影视| 欧美日韩在线亚洲一区蜜芽| 亚洲国产第一页| 一区二区亚洲精品| 久久久999精品视频| 欧美一级视频精品观看| 国产精品日本欧美一区二区三区| 亚洲精品少妇| 99pao成人国产永久免费视频| 另类天堂av| 亚洲国产成人高清精品| 亚洲第一福利视频| 美女视频网站黄色亚洲| 欧美阿v一级看视频| 亚洲第一页自拍| 久久亚洲综合网| 欧美激情一级片一区二区| 亚洲国产欧美在线人成| 嫩草影视亚洲| 亚洲毛片av| 亚洲天堂av综合网| 国产精品xxxxx| 亚洲男人第一网站| 久久手机精品视频| 亚洲国产精品激情在线观看| 欧美成人自拍视频| 亚洲精品在线二区| 香蕉久久国产| 在线观看国产日韩| 欧美风情在线观看| 一本色道久久综合亚洲二区三区| 亚洲一二区在线| 国产欧美日韩在线| 久久久久久久999精品视频| 欧美成人四级电影| 亚洲视频狠狠| 国产亚洲人成a一在线v站| 久久麻豆一区二区| 亚洲精品中文字幕在线| 久久高清免费观看| 亚洲国产日韩在线一区模特| 欧美日韩精品一区二区| 欧美一区二区在线播放| 欧美激情视频网站| 亚洲欧美日韩直播| 亚洲国产成人av| 欧美视频中文字幕在线| 久久精品午夜| 中文在线资源观看视频网站免费不卡| 久久精品一二三区| 99ri日韩精品视频| 国内成人精品2018免费看| 欧美国内亚洲| 欧美中文字幕视频在线观看| 亚洲精品乱码久久久久| 久久狠狠婷婷| 一区二区三区高清| 亚洲成在线观看| 国产欧美欧洲在线观看| 欧美日本国产| 美日韩精品视频| 午夜精品久久久| 日韩一二三区视频| 欧美大片18| 久久久九九九九| 亚洲夜间福利| 日韩一级不卡| 亚洲高清不卡在线| 国产一区二区三区免费观看| 欧美日韩免费观看一区=区三区| 久久久免费av| 欧美一区二区三区四区在线观看地址| 日韩午夜免费| 亚洲人久久久| 亚洲第一中文字幕在线观看| 久久久欧美精品sm网站| 性一交一乱一区二区洋洋av| 一区二区日韩免费看| 亚洲精品日韩精品| 亚洲国产精品一区二区尤物区| 国产一区二区三区免费不卡| 国产伦精品一区二区三区视频孕妇 | 亚洲综合日韩| 99re亚洲国产精品| 最新成人av在线| 亚洲大胆人体视频| 欧美承认网站| 欧美激情精品| 亚洲成色777777女色窝| 欧美高清在线视频观看不卡| 另类专区欧美制服同性| 老鸭窝亚洲一区二区三区| 老司机一区二区| 欧美成人69av| 亚洲电影中文字幕| 亚洲国产成人不卡| 亚洲精品少妇网址| 一区二区三区免费看| 亚洲尤物在线| 久久精品官网| 另类成人小视频在线| 欧美第一黄色网| 欧美日韩国产黄| 国产精品成人一区二区网站软件 | 久久久久久999| 农夫在线精品视频免费观看| 欧美不卡视频一区| 亚洲电影av| av成人动漫| 久久成人精品无人区| 麻豆91精品| 欧美日韩xxxxx| 国产精品亚洲综合天堂夜夜| 国产无一区二区| 亚洲精美视频| 亚洲欧美韩国| 欧美/亚洲一区| 一区二区欧美亚洲| 欧美专区福利在线| 欧美激情导航| 国产日韩欧美另类| 亚洲激情综合| 欧美一级电影久久| 欧美电影在线观看| 亚洲一区二区免费看| 久久一区欧美| 国产精品久久久一区麻豆最新章节| 国产一区二区三区电影在线观看| 91久久综合| 久久精品二区三区| 亚洲精品久久在线| 久久久福利视频| 欧美视频日韩视频| 久久免费视频在线观看| 亚洲精品专区| 久久九九精品| 国产精品久久91| 亚洲三级国产| 久久久久综合一区二区三区| 亚洲精品国产系列| 久久精品国产一区二区三| 欧美日精品一区视频| 亚洲国产欧美国产综合一区| 亚洲影音一区| 亚洲第一福利社区| 久久国产加勒比精品无码| 欧美日韩一级黄| 亚洲精品黄色| 老司机午夜免费精品视频| 亚洲欧美国产一区二区三区| 欧美日韩国产一中文字不卡| 在线日韩av片| 久久夜色撩人精品| 午夜一区二区三视频在线观看| 欧美日韩一区国产|