使用fork()调用计算Fibonacci数列 下载本文

内容发布更新时间 : 2024/9/20 0:56:27星期一 下面是文章的全部内容请认真阅读。

实验二 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,fibn=fibn-1+fibn-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,\ }

pid=fork(); //printf(\ \ if(pid<0) { fprintf(stderr,\ exit(-1); } else if(pid==0) {

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

f2=f0+f1; f0=f1; f1=f2;

printf(\ }

printf(\ } else { wait(NULL); printf(\ } return 0; }

实验结果