操作系统实践报告.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
- . z 操作系统实践报告 多进程题目 sh1.c: 实现shell程序,要求具备如下功能 支持命令参数 $ echo arg1 arg2 arg3 $ ls /bin /usr/bin /home 实现置命令cd、pwd、e*it $ cd /bin $ pwd /bin 思路: 说明:首先设置一个死循环模仿shell终端,读取用户的输入,并且根据空格将输入拆分成字符串数组,然后调用e*cute这个子函数进展处理。 echo 根据数组第一个元素来判断命令是什么,判断出是ehco后,fork一个新的进程,将其后的容一个个输出出来,并且父进程等待子进程退出后再执行,确保输出在屏幕上时不被打断。 ls 读取用户输入并且根据拆分的数组判断出是ls命令后,fork一个新的进程,调用e*eclp函数将/bin/ls下的ls程序装入子进程并将拆分的数组参数局部传递给ls即可,同样的,父进程等待子进程退出,确保输出在屏幕上不被打断。 cd 同样是根据输入并拆分成数组后判断出是cd命令后,fork一个新的进程,然后调用chdir并将拆分数组的参数局部传递给chdir作为实参即可。 pwd 同样是根据输入并拆分成数组后判断出是pwd命令后,fork一个新的进程,然后调用system(pwd)即可,此命令也可以用来验证上面的cd命令是否正确执行。 e*it 根据用户输入逼格拆分的数组判断出是e*it命令后,e*cute子函数返回-1,在循环中检测e*cute的返回值,如果是-1则直接return,退出模仿的shell终端。 sh2.c: 实现shell程序,要求在第1版的根底上,添加如下功能 实现文件重定向 $ echo hello log $ cat log Hello 思路: 接sh1.c的描述,假设判断出是echo命令后,要再次判断拆分的字符串数组中有无〞出现,如果有,则把〞之前、echo之后的容作为输出,把〞之后到〞之后的第一个空白字符作为文件名,fopen创立文件并fwrite将输出容输出到该文件中,并关闭文件。 sh1.c和sh2.c的源代码: #include stdio.h #include unistd.h #include ftl.h #include string.h #include sys/types.h #include sys/wait.h #include stdlib.h #define LEN 256 #define WIDTH 256 #define HEIGHT 10 void split(char source[],char dest[HEIGHT][WIDTH]) { char *p; p=strsep(source,); int i=0; for(i=0;p[i]!=\0;i++){ dest[0][i]=p[i]; } dest[0][i]=\0; int j=1; while(p){ p=strsep(source,); if(p){ for(i=0;p[i]!=\0;i++){ dest[j][i]=p[i]; } dest[j][i]=\0; j++; } } } int e*ecute(char m[HEIGHT][WIDTH]) { if(strcmp(m[0],echo)==0){ int pid=fork(); if(pid==0){ int i=0; int is=0; for(i=1;m[i][0]!=\0;i++){ if(m[i][0]==){ is=1; break; } } if(is==1){ puts(m[i+1]); FILE *fp=fopen(m[i+1],w+); int j=0; for(j=1;ji;j++){ fseek(fp,0,SEEK_END); fwrite(m[j],strlen(m[j]),1,fp); } fclose(fp); }else{ int j=0; for(j=1;m[j][0]!=\0;j++){ printf(%s,m[j]); printf(); } printf(\n); } }else{ int status; wait(status); } }else if(strcmp(m[0],ls)==0){

文档评论(0)

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

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

1亿VIP精品文档

相关文档