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

我要啦免费统计
實驗室老是中毒,今天差點連代碼都保不住了
貼貼備份
進程調度 實驗一 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 閱讀(4285) 評論(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在线视频观看| 美女久久一区| 99av国产精品欲麻豆| 亚洲自拍偷拍色片视频| 欧美资源在线观看| 欧美日本簧片| 香蕉免费一区二区三区在线观看| 久久久99精品免费观看不卡| 欧美激情在线免费观看| 亚洲欧美不卡| 激情久久中文字幕| 亚洲视频二区| 久久亚洲视频| 亚洲一区在线免费观看| 欧美va亚洲va香蕉在线| 国产精品美女xx| 在线观看国产精品淫| 午夜精品短视频| 日韩午夜一区| 国产欧美欧美| 一区二区av在线| 欧美a级片网| 欧美日韩一二三四五区| 国产综合激情| 欧美一区二区三区免费视频| 亚洲乱码国产乱码精品精 | 亚洲主播在线观看| 亚洲黄一区二区三区| 亚洲特级片在线| 欧美一级理论片| 国产精品少妇自拍| 亚洲欧美日韩国产精品| 一本色道婷婷久久欧美| 欧美成人精品影院| 亚洲高清视频在线观看| 久久免费午夜影院| 欧美视频在线播放| 日韩视频免费看| 欧美二区在线看| 欧美gay视频激情| 久久精品国产99| 午夜精品三级视频福利| 国产日本欧美一区二区| 亚洲日本中文| 欧美性猛交xxxx乱大交蜜桃| 亚洲视频免费观看| 免费日韩精品中文字幕视频在线| 欧美一级大片在线观看| 欧美日韩精品伦理作品在线免费观看| 亚洲另类自拍| 久久综合图片| 亚洲激情国产| 99国产精品久久久久老师| 国产精品高潮呻吟久久| 欧美一级理论片| 欧美视频一区二区在线观看 | 亚洲视频导航| 欧美日韩高清在线一区| 亚洲激情视频在线播放| 在线观看成人网| 久久另类ts人妖一区二区| 亚洲欧洲另类国产综合| 亚洲最新色图| 亚洲一区二区动漫| 香港久久久电影| 欧美一级一区| 国产午夜精品全部视频播放 | 亚洲一区国产精品| 欧美视频免费| 中文网丁香综合网| 1024成人网色www| 99国产精品99久久久久久粉嫩| 亚洲区中文字幕| 欧美精品成人91久久久久久久| 亚洲欧美bt| 国产一区二区三区不卡在线观看| 美女脱光内衣内裤视频久久网站| 一区二区三区在线观看视频| 久久久久久久国产| 蜜月aⅴ免费一区二区三区| 亚洲高清电影| 欧美日韩三级一区二区| 亚洲午夜精品久久久久久浪潮| 韩曰欧美视频免费观看| 一区二区三区免费观看| 午夜在线观看免费一区| 激情欧美一区| 欧美精品一区二区三区一线天视频 | 韩国在线视频一区| 毛片av中文字幕一区二区| 欧美亚洲视频| 激情综合亚洲| 欧美日韩国产区| 欧美亚洲视频一区二区| 欧美va亚洲va日韩∨a综合色| 99视频精品全国免费| 国产精品视频久久| 免费的成人av| 亚洲制服少妇| 亚洲国产日韩一区| 国产中文一区| 欧美激情在线免费观看| 亚洲女性裸体视频| 亚洲国产日韩欧美在线99 | 亚洲国产精品一区在线观看不卡 | 久久久一区二区三区| 日韩视频一区| 欧美波霸影院| 欧美一区国产二区| 亚洲理论在线观看| 黄色av一区| 国产精品99免费看 | 亚洲精品视频在线看| 欧美有码视频| 一区二区三区精密机械公司| 牛牛精品成人免费视频| 亚洲欧美国产三级| 亚洲欧洲一区二区在线观看 | 亚洲少妇在线| 亚洲国产视频一区| 国产日韩一区二区三区| 欧美日韩视频| 欧美精选在线| 免费日韩视频| 久久久久国产精品午夜一区| 亚洲婷婷免费| 99精品国产在热久久婷婷| 欧美va亚洲va香蕉在线| 久久精品中文字幕免费mv| 亚洲一级高清| 中文一区字幕| 一区二区日韩免费看| 亚洲精品美女久久7777777| 欧美日韩p片| 欧美黄网免费在线观看| 亚洲免费观看视频| 亚洲国产视频一区二区| 欧美成人一区二区三区在线观看 | 亚洲福利视频三区| 一区二区三区|亚洲午夜| 亚洲大片精品永久免费| 激情久久综艺| 在线国产精品播放| 亚洲国产电影| 亚洲欧洲日本国产| 亚洲精品一区在线| 99精品黄色片免费大全| 你懂的网址国产 欧美| 亚洲欧美一区二区精品久久久| 亚洲欧洲三级电影| 欧美电影打屁股sp| 亚洲日本中文字幕免费在线不卡| 亚洲韩国一区二区三区| 亚洲茄子视频| 亚洲视频碰碰| 午夜精品视频网站| 久久久999精品视频| 久久中文精品| 欧美日韩黄视频| 国产精品美腿一区在线看 | 欧美日韩国产精品成人| 欧美日韩在线大尺度| 国产精品久久久一区二区三区| 国产精品美女主播在线观看纯欲| 国产免费成人| 欧美大片免费观看| 欧美日韩免费一区| 国产精品综合久久久| 激情久久影院| 一区二区三区高清在线| 性18欧美另类| 欧美大片免费观看| 在线亚洲成人| 久久亚洲精品视频| 亚洲欧美一区二区精品久久久| 亚洲国产精品成人精品| 中文av一区二区| 久久精品视频播放| 欧美日韩在线播放| 尤妮丝一区二区裸体视频| 一区二区三区精品视频| 久久久成人网| 99在线热播精品免费99热| 久久成人18免费观看| 欧美日韩天堂| 亚洲福利在线视频| 亚洲欧美日韩一区二区| 欧美激情在线免费观看| 午夜精品久久久久久久久| 欧美+亚洲+精品+三区| 国产欧美日韩在线播放| 亚洲免费电影在线观看| 久久尤物视频| 亚洲欧美日韩一区| 欧美日本国产| 亚洲黄色片网站| 久久综合久色欧美综合狠狠|