2014-11-16 22 views
0

我在用C语言编写的以下代码中挣扎。它在执行时给出分段错误。 的错误出现在行调试C代码时没有错误,但执行时会出现SEGMENTATION错误。为什么?

scanf("%d %d %d %d",&(plist[i]->arrival),&(plist[i]->burst),&(plist[i]->deadline),&(plist[i]->period)); 

以下是整个代码没有给出编译错误的执行,但运行时错误。 如果有人在这里可以告诉我我在哪里犯错,这将是我非常棒的。

#include <stdio.h> 
#include <stdlib.h> 
#define INT_MAX 9999999 
struct task 
{ 
int arrival,burst,period,deadline,remaining,flag; 
}; 
void main() 
{ 
int i,n,time,flags=0,smallest; 
struct task *list,**plist; 
printf("\nEnter number of tasks :: "); 
scanf("%d",&n); 
list= (struct task *)malloc(sizeof(struct task)*n+1); 

plist=(struct task **)malloc(sizeof(struct task*)*n+1); 

for (i=0;i<=n;++i) 
{ 
    plist[i]=&list[i]; 
} 
plist[n]->deadline=plist[n]->remaining=plist[n]->arrival=INT_MAX; 
for (i=0;i<n;++i) 
{ 
    printf("\nEnter Arrival time, Burst time, Deadline & Period of task T%d ::",i); 
    scanf("%d %d %d %d",&(plist[i]->arrival),&(plist[i]->burst),&(plist[i]->deadline),&(plist[i]->period)); 
    plist[i]->flag=0; 
    plist[i]->remaining=plist[i]->burst; 
} 
for(time=0;;time++) 
{ 

    smallest=n; 
    for(i=0;i<n+1;++i) 
    { 
     if(plist[i]->arrival<=time && 
     plist[i]->deadline<plist[smallest]->deadline && 
     plist[i]->remaining>0) 
     { 
      smallest=i; 
     } 
    } 
    plist[smallest]->remaining--; 
    if(plist[smallest]->remaining==0) 
    { 
     if((plist[smallest]->flag==0)) 
     { 
      plist[smallest]->arrival=0; 
     } 

     plist[smallest]->flag=1; 

     plist[smallest]->arrival+=plist[smallest]->period; 



     plist[smallest]->remaining=plist[smallest]->burst; 
        printf("\nTask T%d completed at time %d.",smallest,time+1); 
        int j; 
        flags=0; 
        for(j=0;j<n;++j) 
        { 
         flags+=plist[j]->flag; 
        } 
    }if(flags==n)break; 
} 
free(plist); 
free(list); 
system("pause");  


} 

回答

1

这里的问题是,在你的代码的结构和指针数组

list= (struct task *)malloc(sizeof(struct task)*n+1); 
plist=(struct task **)malloc(sizeof(struct task*)*n+1); 

但是你的[n]指数显示,你需要分配一个额外的数组元素分配一个额外的字节每个,所以你需要左右括号(n+1)

list= (struct task *)malloc(sizeof(struct task)*(n+1)); 
plist=(struct task **)malloc(sizeof(struct task*)*(n+1)); 
+0

这是一个愚蠢的错误,但很难辨认。非常感谢。 –

相关问题