简单shell设计
思路:将输入的命令字符串解析为一个个字符串指针,放在argv数组里。
fork创建子进程,execvp进程替换,让子进程执行新的命令,父进程等待子进程结束后循环读入下一条命令。
#include <unistd.h>
#include <stdio.h>
#include <string.h>
#include <fcntl.h>
void parse(char *cmd)
{
char *argv[10];
int argc = 0;
int flag = 0;
int i = 0;
//解析命令字符串,利用状态机思想
for(i=0; cmd[i]!='\0'; i++){
//从空格状态切换到命令状态
if(!isspace(cmd[i]) && flag == 0){
flag = 1;
argv[argc++] = &cmd[i];
}
else if(isspace(cmd[i])){
flag = 0;
cmd[i] = '\0';
}
}
//最后放空指针
argv[argc] = NULL;
myexec(argc, argv);
}
void myexec(int argc, char *argv[]){
pid_t pid;
if((pid = fork()) == 0){
//子进程替换
//查看命令中是否有 > 重定向
int i, flag = 0;
for(i=0; i< argc; i++){
printf("%s ", argv[i]);
fflush(stdout);
if(strcmp(argv[i], ">") == 0){
flag = 1;
break;
}else if(strcmp(argv[i], ">>")== 0){
flag = 2;
break;
}
}
printf("flag %d", flag);
argv[i] = NULL;
if(flag == 1){
int fd = open(argv[i+1], O_WRONLY|O_CREAT, 0644);
close(1);
dup(fd);
}else if(flag == 2){
printf("%s", argv[i+1]);
fflush(stdout);
int fd = open(argv[i+1], O_WRONLY|O_APPEND, 0644);
close(1);
dup(fd);
}ecvp(argv[0], argv);
printf("commnd %d not found\n", argv[0]);
exit(1);//异常退出
}
else{
//父进程
int status = 0;
waitpid(pid, &status, 0);
}
}
int main()
{
char cmd[50];
while(1){
printf("Root $");
memset(cmd, 0, sizeof(char));
//读取一行带空格的串
scanf("%[^\n]%*c", cmd);
parse(cmd);
}
}
缓慢显示文件内容
按行读取文件内容,每显示一个单词,停顿一秒。
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <unistd.h>
#include <ctype.h>
void getLine(FILE *fp, char *buf, int length)
{
char c;
int i = 0;
memset(buf, 0, length);
do{
c = fgetc(fp);
if(c == EOF){
exit(0);
}
buf[i++] = c;
}while(c!='\n' && i<length);
}
int main()
{
char fileName[100];
char buf[1024];
int i = 0;
scanf("%s", fileName);
printf("%s", fileName);
FILE *fp = fopen(fileName, "r");
if(NULL == fp){
fprintf(stderr, "%s error", fileName);
}
while(1){
getLine(fp, buf, 1024);
for(i=0; buf[i]!='\0'; i++){
if(isspace(buf[i])){
printf("%c", buf[i]);
fflush(stdout);
}
else{
while(buf[i] && !isspace(buf[i])){
printf("%c", buf[i]);
fflush(stdout);
i++;
}
i--;
sleep(1);
}
}
}
}