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

  1. 1、本文档共3页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验二 Linux 进程创建 实验目的 加深对进程概念的理解 练习使用fork()系统调用创建进程 练习Linux操作系统下C程序设计 实验准备知识 1. fork()函数:创建一个新进程. 调用格式: #include sys/types.h #include unistd.h 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 stdio.h #include stdlib.h #include unistd.h #include sys/types.h 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(pid0) { 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; } 实验结果

文档评论(0)

_______ + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档