[英]dup2 causes program to halt
int shell (int argc, char *argv[]) {
char *s = malloc(INPUT_STRING_SIZE+1); /* user input string */
tok_t *t; /* tokens parsed from input */
int lineNum = 0;
int fundex = -1;
pid_t pid = getpid(); /* get current processes PID */
pid_t ppid = getppid(); /* get parents PID */
pid_t cpid, tcpid, cpgid;
init_shell();
printf("%s running as PID %d under %d\n",argv[0],pid,ppid);
lineNum=0;
const int BUF_SIZE = 200;
char buf[BUF_SIZE];
getcwd(buf, BUF_SIZE);
fprintf(stdout, "%d %s: ", lineNum++, buf);
while ((s = freadln(stdin))){
char *ptrA, *ptrB;
ptrA = strstr(s, "<");
ptrB = strstr(s, ">");
if (ptrA) {
*ptrA = '\0';
ptrA++;
}
if (ptrB) {
*ptrB = '\0';
ptrB++;
}
if (ptrA && ptrB) {
} else if (ptrA) {
} else if (ptrB) {
size_t ln = strlen(ptrB) - 1;
if (ptrB[ln] == '\n') // get rid of the trailing newline
ptrB[ln] = '\0';
int newfd; /* new file descriptor */
if ((newfd = open(ptrB, O_CREAT|O_TRUNC|O_WRONLY, S_IRUSR|S_IWUSR|S_IXUSR)) < 0) {
perror("Can't open outfile file\n"); /* open failed */
exit(1);
}
printf("newfd: %d\n", newfd);
dup2(newfd, 1);
printf("Here\n");
}
printf("%s\n", s);
t = getToks(s); /* break the line into tokens */
fundex = lookup(t[0]); /* Is first token a shell literal */
if(fundex >= 0) {
cmd_table[fundex].fun(&t[1]);
} else {
char *bin;
if (get_binary(t[0], &bin) == 0) {
t[0] = bin;
}
pid_t child_pid = fork();
int exit_code;
if (child_pid == 0) {
execv(t[0], &t[0]);
} else {
wait(&exit_code);
}
}
getcwd(buf, BUF_SIZE);
fprintf(stdout, "%d %s: ", lineNum++, buf);
}
return 0;
}
我用wc shell.c>test
测试了我的shell, wc shell.c>test
是我在终端上得到了空行,好像它在等待我的输入一样。 当我按Enter键时,它会出现段错误。 如果我注释掉dup2行,那么外壳将完美地工作(当然,无需重定向)。 如果有帮助,我正在Windows上使用Cygwin。
我的偶偶放错了地方。 分叉后但执行前,我需要翻拍。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.