操作系统实验报告shell程序计算机linuxUnix相关_计算机-计算机原理.pdf
《操作系统实验报告shell程序计算机linuxUnix相关_计算机-计算机原理.pdf》由会员分享,可在线阅读,更多相关《操作系统实验报告shell程序计算机linuxUnix相关_计算机-计算机原理.pdf(14页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、 操作系统实习报告 日期:实习题目:shell 程序 完 姓名:组号:学号 成 人 实习 内容 简要 描述 主 要 代 码 结构 (附 注 释)本实验要实现一个简单的命令解释器,也就是 Linux 中的 shell 程序。实验程序起名为 ysh,要求其设计类似于目前流行的 shell 解释程序,如 bash、csh、tcsh,但不需要具备那 么复杂的功能。ysh 程序应当具有如下一些重要的特征:能够执行外部程序命令,命令可以带参数。能够执行 fg、bg、cd、history、exit 等内部命令。使用管道和输入输出重定向。支持前后台作业,提供作业控制功能,包括打印作业的清单,改变当前运行作业的
2、前台/后台状态,以及控制作业的挂起、中止和继续运行。除此之外,在这个实验中还须做到:使用 make 工具建立工程。使用调试器 gdb 来调试程序。提供清晰、详细的设计文档和解决方案。#include#include#include#include#include#include#include#include#include#include#include#include ysh.h#define NO_PIPE-1#define FD_READ 0#define FD_WRITE 1 int is_founded(char*cmd)int k=0;while(envpathk!=NULL)s
3、trcpy(buf,envpathk);strcat(buf,cmd);if(access(buf,F_OK)=0)return 1;k+;return 0;void getenviron(int n,char*s)int i=0,j=0,k=0;char c;char buff80;char*p;while(c=si)!=)buffi+=c;buffi+=0;if(strcmp(buff,PA TH)=0)while(si!=0)if(si=:)buffj+=/;buffj=0;p=(char*)malloc(strlen(buff)+1);strcpy(p,buff);envpathk+=
4、p;envpathk=NULL;j=0;i+;else buffj=si;j+;i+;else fprintf(stderr,No match);int getline(int fd,char*buf)int i=0;char c;while(read(fd,&c,1)bufi+=c;if(c=n)bufi-1=0;return i;return i;void init_environ()int fd,n;char buf80;if(fd=open(ysh_profile,O_RDONLY,660)=-1)printf(init environ variable error!n);exit(1
5、);个简单的命令解释器也就是中的程序实验程序起名为要求其设计类似于目前流行的解释程序如但不需要具备那么复杂的功能程序应当具有如下一些重要的特征能够执行外部程序命令命令可以带参数能够执行等内部命令使用管道和输业的挂起中止和继续运行除此之外在这个实验中还须做到使用工具建立工程使用调试器来调试程序提供清晰详细的设计文档和解决方案通过本次实验使我们熟悉使用结果在编写系统应用程序时熟练使用分析学习使用系统调用对进程解并发程序中的同步问题原因锻炼在团队成员之间的交流与合作能力分析注释如果上述表格空间不够可以另附表格进行说明 while(n=getline(fd,buf)!=0)getenviron(n,b
6、uf);envhis.start=0;envhis.end=0;head=end=NULL;int pipel(char*input,int len)char*argv1030;char*filename0;int i,j,k,is_bg=0;int li_cmd=0;int fd101,pipe_in=-1;int pipe_out=-1,flag=0;pid_t pid;for(i=0,j=0,k=0;i)|(inputi=n)if(inputi=|)|(inputi=)if(inputi=)flag=1;if(j 0)bufj+=0;argvli_cmdk=(char*)malloc(s
7、izeof(char)*j);strcpy(argvli_cmdk,buf);k+;argvli_cmdk=(char*)0;li_cmd+;k=0;j=0;if(j=0)continue;else bufj+=0;if(flag=0)argvli_cmdk=(char*)malloc(sizeof(char)*j);strcpy(argvli_cmdk,buf);k+;else filename0=(char*)malloc(sizeof(char)*j);个简单的命令解释器也就是中的程序实验程序起名为要求其设计类似于目前流行的解释程序如但不需要具备那么复杂的功能程序应当具有如下一些重要的特
8、征能够执行外部程序命令命令可以带参数能够执行等内部命令使用管道和输业的挂起中止和继续运行除此之外在这个实验中还须做到使用工具建立工程使用调试器来调试程序提供清晰详细的设计文档和解决方案通过本次实验使我们熟悉使用结果在编写系统应用程序时熟练使用分析学习使用系统调用对进程解并发程序中的同步问题原因锻炼在团队成员之间的交流与合作能力分析注释如果上述表格空间不够可以另附表格进行说明 strcpy(filename0,buf);j=0;else if(inputi=&)&(inputi=0)is_bg=1;continue;bufj+=inputi;argvli_cmdk+=NULL;for(i=0;i
9、=10;i+)fdiFD_READ=NO_PIPE;fdiFD_WRITE=NO_PIPE;for(i=0;i li_cmd;i+)if(pipe(fdi)=-1)printf(Can not open pipe!n);return 0;for(i=0;i li_cmd;i+)if(is_founded(argvi0)=0)printf(Can not found command!n);break;if(i!=0)pipe_in=fdi-1FD_READ;else pipe_in=NO_PIPE;if(i!=li_cmd)pipe_out=fdiFD_WRITE;else if(flag=1)
10、if(pipe_out=open(filename0,O_WRONLY|O_CREA T|O_TRUNC,S_IRUSR|S_IWUSR)=-1)printf(Can not open%sn,filename0);return 0;else 个简单的命令解释器也就是中的程序实验程序起名为要求其设计类似于目前流行的解释程序如但不需要具备那么复杂的功能程序应当具有如下一些重要的特征能够执行外部程序命令命令可以带参数能够执行等内部命令使用管道和输业的挂起中止和继续运行除此之外在这个实验中还须做到使用工具建立工程使用调试器来调试程序提供清晰详细的设计文档和解决方案通过本次实验使我们熟悉使用结果在编写系
11、统应用程序时熟练使用分析学习使用系统调用对进程解并发程序中的同步问题原因锻炼在团队成员之间的交流与合作能力分析注释如果上述表格空间不够可以另附表格进行说明 pipe_out=NO_PIPE;if(pid=fork()0)printf(Fork failed!n);return 0;if(pid=0)if(pipe_in=NO_PIPE)close(pipe_in);if(pipe_out=NO_PIPE)close(pipe_out);if(pipe_out!=NO_PIPE)dup2(pipe_out,1);close(pipe_out);if(pipe_in!=NO_PIPE)dup2(p
12、ipe_in,0);close(pipe_in);execv(buf,argvi);else if(is_bg=0)waitpid(pid,NULL,0);close(pipe_in);close(pipe_out);return 0;void add_history(char*inputcmd)envhis.end=(envhis.end+1)%HISNUM;if(envhis.end=envhis.start)envhis.start=(envhis.start+1)%HISNUM;strcpy(envhis.his_cmdenvhis.end,inputcmd);void history
13、_cmd()int i,j=0;if(envhis.start=envhis.end)个简单的命令解释器也就是中的程序实验程序起名为要求其设计类似于目前流行的解释程序如但不需要具备那么复杂的功能程序应当具有如下一些重要的特征能够执行外部程序命令命令可以带参数能够执行等内部命令使用管道和输业的挂起中止和继续运行除此之外在这个实验中还须做到使用工具建立工程使用调试器来调试程序提供清晰详细的设计文档和解决方案通过本次实验使我们熟悉使用结果在编写系统应用程序时熟练使用分析学习使用系统调用对进程解并发程序中的同步问题原因锻炼在团队成员之间的交流与合作能力分析注释如果上述表格空间不够可以另附表格进行说明
14、return;else if(envhis.start envhis.end)for(i=envhis.start+1;i=envhis.end;i+)printf(%dt%sn,j,envhis.his_cmdi);j+;else for(i=envhis.start+1;i HISNUM;i+)printf(%dt%sn,j,envhis.his_cmdi);j+;for(i=0;i=envhis.end;i+)printf(%dt%sn,j,envhis.his_cmdi);j+;void cd_cmd(char*route)if(route!=NULL)if(chdir(route)p
15、id,p-state,p-cmd);i+;p=p-link;while(p!=NULL);else printf(No jobs!n);void add_node(char*input_cmd,int node_pid)struct NODE*p;个简单的命令解释器也就是中的程序实验程序起名为要求其设计类似于目前流行的解释程序如但不需要具备那么复杂的功能程序应当具有如下一些重要的特征能够执行外部程序命令命令可以带参数能够执行等内部命令使用管道和输业的挂起中止和继续运行除此之外在这个实验中还须做到使用工具建立工程使用调试器来调试程序提供清晰详细的设计文档和解决方案通过本次实验使我们熟悉使用结果在
16、编写系统应用程序时熟练使用分析学习使用系统调用对进程解并发程序中的同步问题原因锻炼在团队成员之间的交流与合作能力分析注释如果上述表格空间不够可以另附表格进行说明 p=(struct NODE*)malloc(sizeof(struct NODE);p-pid=node_pid;strcpy(p-state,input_cmd);strcpy(p-state,running);p-link=NULL;if(head=NULL)head=p;end=p;else end-link=p;end=p;void del_node(int sig,siginfo_t*sip)struct NODE*q;s
17、truct NODE*p;int id;if(sig_z=1)sig_z=0;goto out;id=sip-si_pid;p=q=head;if(head=NULL)goto out;while(p-pid!=id&p-link!=NULL)p=p-link;if(p-pid!=id)goto out;if(p=head)head=head-link;else while(q-link!=p)q=q-link;if(p=end)end=q;q-link=NULL;else q-link=p-link;个简单的命令解释器也就是中的程序实验程序起名为要求其设计类似于目前流行的解释程序如但不需要具
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 操作系统 实验 报告 shell 程序 计算机 linuxUnix 相关 原理
限制150内