生活随笔
收集整理的這篇文章主要介紹了
操作系统上机作业--实现shell(2)(多进程)
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
sh2.c: 實現(xiàn)shell程序,要求在第1版的基礎(chǔ)上,添加如下功能
? 實現(xiàn)文件重定向
? $ echo hello >
log
? $ cat
log
? Hello
實現(xiàn)思路:
和sh1.c相比,主要是修改了cmd函數(shù)的實現(xiàn)過程。通過循環(huán)找出重定向符號">"的位置,記錄下來,并記錄下重定向符號后面的文件名,open該文件,然后創(chuàng)建一個子進程,在子進程中,使用dup2()函數(shù)將本來要輸出到屏幕的數(shù)據(jù),重定向到我們剛打開的文件中,然后使用execvp()函數(shù)裝載外部命令。
代碼:
#include<stdio.h>
#include<sys/wait.h>
#include<unistd.h>
#include<sys/types.h>
#include<stdlib.h>
#include<string.h>
#include<pwd.h>
#include<fcntl.h>#define MAX_PATH_LEN 200
#define CMD_LEN 200
int cmd_num;
char *cmd_array[
100];
void cmd(){pid_t pid;
int i;
int newFd;
for(i=
0;i<cmd_num;i++)
if(
strcmp(cmd_array[i],
">")==
0){cmd_array[i]=NULL;newFd=open(cmd_array[i+
1],O_RDWR|O_CREAT,
400,
200);
if(newFd==-
1){
printf(
"Error:can't open the file\n");
exit(
0);}
break;}pid=fork();
if(pid==
0){dup2(newFd,
1);close(newFd);
if(execvp(cmd_array[
0],cmd_array)<
0){
printf(
"Error:command not found\n");}}wait(NULL);
}
void print_user(){
struct passwd *pwd;
char path_name[MAX_PATH_LEN];getcwd(path_name,MAX_PATH_LEN);pwd=getpwuid(getuid());
printf(
"%s@kali:%s$ ",pwd->pw_name,path_name);
}
void get_cmd(){
int i=
0;
char str[CMD_LEN];
char *buf;cmd_num=
0;
memset(cmd_array,
0,
100);fgets(str,CMD_LEN,stdin);buf=strtok(str,
" \n");
while(buf!=NULL){cmd_array[i]=(
char *)
malloc(
sizeof(*buf));
strcpy(cmd_array[i++],buf);buf=strtok(NULL,
" \n");}cmd_array[i]=NULL;cmd_num=i;
}
void mycd(){
struct passwd *pwd;
char path_name[MAX_PATH_LEN];pwd=getpwuid(getuid());
if(cmd_num==
1){
strcpy(path_name,pwd->pw_dir);
if(chdir(path_name)==-
1){perror(
"mycd:chdir..");
exit(
1);}}
else{
if(chdir(cmd_array[
1])==-
1){
printf(
"mycd: cd:%s:No such directory\n",cmd_array[
1]);}}
}
void myexit(){
exit(
0);
}
void mypwd(){
char path_name[MAX_PATH_LEN];
if(getcwd(path_name,MAX_PATH_LEN)){
printf(
"%s\n",path_name);}
else{perror(
"Error:getcwd...\n");
exit(
0);}
}
int main(){
while(
1){print_user();get_cmd();
if(cmd_array[
0]==NULL)
return 0;
else if(
strcmp(cmd_array[
0],
"exit")==
0)myexit();
else if(
strcmp(cmd_array[
0],
"pwd")==
0)mypwd();
else if(
strcmp(cmd_array[
0],
"cd")==
0)mycd();
else cmd();}
return 0;
}
歡迎留言交流。。。
總結(jié)
以上是生活随笔為你收集整理的操作系统上机作业--实现shell(2)(多进程)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。