wait () & в петле partent - PullRequest
0 голосов
/ 13 мая 2018
#include <stdio.h>
#include <unistd.h>
#include <string.h>
#include <stdlib.h>

void main(){
   int x,y,status, i;
   int cnt = 0;
   int flag = 0;
   char buf[50];
   char str[50];
   char * argv[10];
   char * ptr;


   for(i=0; i<10; i++){
    printf("$");
    gets(buf);
    strcpy(str, buf);

    ptr = strtok(buf, " ");

    while(ptr != NULL){
      argv[cnt] = ptr;
      cnt++;
      ptr = strtok(NULL," ");
    }



    if(!strcmp(argv[cnt-1], "&")) {
      argv[cnt-1] = 0;
      flag = 1;
    }
    else {
        argv[cnt] = 0;
    }



    if(!strcmp(argv[0],"exit")) exit(0);

    x=fork();

    if (x==0){
        sleep(1);
        printf("I am child to execute %s\n", str);
        y=execve(argv[0], argv, 0);

        if (y<0){
           perror("exec failed");
           exit(1);
        }

    }
    else {
      if(flag == 0) { 
          wait(&status); 
      }
    }


    flag = 0;
    cnt = 0;
   }
}

Я хочу выполнить фон с '&'

, как настоящая оболочка linux

, поэтому я поделился

   else {
      if(flag == 0) { 
          wait(&status); 
      }
    }

как это

так что он работает хорошо

если я введу / bin / ls (без &) приглашение $ будет помещено после / bin / ls

и если я введу / bin / ls & (с &)тогда приглашение $ ставится перед / bin / ls

, но переписываете / bin / ls (без &), как при первом вводе, тогда приглашение $ ставится перед / bin / ls

почему?

===============

$/bin/ls
I am child to execute /bin/ls
ch f1 f2 shell shell.c t t.c test test.c testfile

$/bin/ls &
$I am child to execute /bin/ls &
ch f1 f2 ch f1 f2 shell shell.c t t.c test test.c testfile

$/bin/ls
$I am child to execute /bin/ls
ch f1 f2 shell shell.c t t.c test test.c testfile

================
Is it right?

1 Ответ

0 голосов
/ 13 мая 2018

Я бы сказал, что ожидается поведение $.

Я даже не знаю, как компилируется этот код.Вы не можете использовать void main(){ (по крайней мере, при использовании gcc).Действительная форма будет int main() {.Кроме того, вы можете значительно упростить свой код:

#include <stdio.h>
#include <unistd.h>
#include <string.h>
#include <stdlib.h>

int main() { /*Changed void main()*/
   int x, y, status, i, cnt=0, flag=0; /*Squashed declarations*/
   char buf[50]; /*removed str*/
   char * argv[10], * ptr;
   for(i=0; i<10; i++){
      putchar('$'); /*printf() is overkill. Also, watch out for this!*/
      fgets(buf, 49, stdin); /*49 (null terminator), gets --> fgets*/
      /*strcpy(str, buf); <-- why?*/
      ptr = strtok(buf, " ");
      while(ptr != NULL) {
          argv[cnt++] = ptr;
          ptr = strtok(NULL," ");
      }
      if(!strcmp(argv[cnt-1], "&")) {
          argv[cnt-1] = 0;
          flag = 1;
      } else {
          argv[cnt] = 0;
      }
      if(!strcmp(argv[0],"exit"))
          return 0;
      x=fork();
      if (!x) {
          sleep(1);
          y=execve(argv[0], argv, 0);

          if (y<0) {
              perror("execve failed");
              return 1;
          }

      } else {
          if(!flag) { 
              wait(&status); 
          }
      }
      flag = 0;
      cnt = 0;
   }
}

Вы создаете дочерние элементы, и в каждом случае вы видите «$» - это заставляет «$» появляться.

После, fork(), «$» снова отображается, даже когда вы выполняете процесс.

...