使用fork()调用计算Fibonacci数列

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

实验二Linux 进程创建

实验目的

⏹加深对进程概念的理解

⏹练习使用fork()系统调用创建进程

⏹练习Linux操作系统下C程序设计

实验准备知识

1. fork()函数:创建一个新进程.

❑调用格式:

#include

#include

int fork();

❑返回值:

正确返回时,等于0表示创建子进程,从子进程返回的ID值;大于0表示从父进程返回的子进程的进程ID值。

错误返回时,等于-1表示创建失败

实验内容:使用fork()调用计算Fibonacci数列

⏹Fibonacci数列是0,1,1,2,3,5,8…….通常表示为:fib0=0,

fib1=1,fib n=fib n-1+fib n-2

⏹写一个C程序,使用fork()系统调用产生一个子进程来计算

Fibonacci数列,序列通过命令行显示。例如,如果参数为5,Fibonacci数列的前5个数字将在子进程中被输出。

⏹因为父进程和子进程拥有各自的数据拷贝,所以需要由子进程

输出。在退出程序之前,父进程调用wait()等待子进程完成。

要求提供必要的错误检测以保证在命令行传递的参数是非负数.

实验程序:

#include

#include

#include

#include

int main(int argc, char* argv[])

{

pid_t pid;

int i;

int f0,f1,f2;

f0=0;

f1=1;

if(argv[1]<0)

{

fprintf(stderr,"request a nun-negative number");

}

pid=fork();

//printf("pid = %d ",pid);

if(pid<0)

{

fprintf(stderr,"fork failed");

exit(-1);

}

else if(pid==0)

{

printf("argv[1] = %d\n",atoi(argv[1]));

printf("0 1 ");

for(i=2; i<=atoi(argv[1]);i++)

{

f2=f0+f1;

f0=f1;

f1=f2;

printf("%d ",f2);

}

printf("\nchild process completed\n");

}

else

{

wait(NULL);

printf("parent process exited");

}

return 0;

}

实验结果

相关文档
最新文档