0

我正在为 FCFS 调度编写此代码。但在 Linux 中,这会给出“分段错误”。如何纠正这样的错误?

 #include<stdio.h>
#include<string.h>
float fxn();

int main()
{

float avgwt;
int n,i,at[10],bt[10];
printf("\n\nEnter the number of processes:");
scanf("%d",&n);
printf("\n\n BURST TIME and ARRIVAL TIME of thr process");
for(i=0;i<n;i++)
{
printf("\n ARRIVAL TIME :");
scanf("%d",&at[i]);
printf(" BURST TIME : ");
scanf("%d",&bt[i]);
}

avgwt=fxn(at,bt,n);

printf("\n\nAverage waiting time=%f",avgwt);
return 0;

}



float fxn( int at[], int bt[], int n)

{

int i,j,t,wt[n],sum,tt[n],q;

float avgwt;


 for(j=i+1;j<n;j++)
  {
   if(at[i]>at[j])

    {
t=at[i];
at[i]=at[j];
at[j]=t;
q=bt[i];
bt[i]=bt[j];
bt[j]=q;
    }
   }


wt[0]=0;


for(i=0;i<n;i++)
{

wt[i+1]=wt[i]+bt[i];
sum=sum+(wt[i+1]-at[i]);

}

avgwt=sum/n;

return avgwt;


}

另一个问题----我将编辑这段代码以在linux中进行系统调用。

如果 ac 程序将从用户那里获取输入并将其传递给内核进行进一步计算,那么数组的传递会起作用吗?

(例如 - 这里 main() 函数用于将输入和 fxn() 函数带入内核

4

2 回答 2

1

您在下面遇到缓冲区溢出

for(i=0;i<n;i++)
{

  wt[i+1]=wt[i]+bt[i];
   sum=sum+(wt[i+1]-at[i]);
  } 

它也应该是i < n -1你需要i=0在函数中初始化fxn

于 2012-04-13T20:07:53.603 回答
1

分段错误/错误是您的程序访问内存(读取或写入)的指标,它不属于您的程序(意味着它没有访问它的“权利”)。这包括对数组成员的访问。

现在,我在您的代码中看到了一个可能且明确的问题:

  1. 您读取了许多进程并填充n了数组at和值。只要最多有 10 个进程,这才是正确的,因为您声明数组的长度只有 10。btn

  2. 在你的函数fxn中(顺便说一句:你确定你不能更好地命名这个函数吗?)你正在创建一个wt长度数组n(你也创建了一个tt你甚至不使用的数组)。技术上正确wt的是所谓的 VLA 或可变长度数组,它尤其只存在于 C99 中,这是大多数编译器仍然不完全支持的 C 标准,因此您可能希望避免这些(例如使用mallocfree)。那么真正的问题是什么?

这:

for(i=0;i<n;i++)
{

wt[i+1]=wt[i]+bt[i];
sum=sum+(wt[i+1]-at[i]);

}

i可以具有从0to的值n-1,因此i+1可以具有n超出数组范围的值,从而wt导致段错误。

您可能还会考虑您的数组wt;你甚至不需要它!只是一个提示。

于 2012-04-13T20:09:16.543 回答