使用fork()调用计算Fibonacci数列
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 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;
}
实验结果