почему функция fork () в моем коде не создает дочерний процесс? - PullRequest
0 голосов
/ 29 декабря 2018

Я пытаюсь написать программу, которая принимает аргументы командной строки для проверки даты, а затем показывает все файлы, измененные после этой даты.По какой-то причине функция fork (), похоже, не создает дочерний процесс и не выполняет соответствующую часть кода, и я не могу понять, почему.какие-либо предложения?

Сами части fork () находятся в строках 59 и 76. Остальная часть кода работает нормально, но функция findafterdate () выполняется только для родительского процесса.

 1 #define _XOPEN_SOURCE
 2 #include <stdio.h>
 3 #include <stdlib.h>
 4 #include <string.h>
 5 #include <time.h>
 6 #include <sys/wait.h>
 7 #include <unistd.h>
 8 #include <sys/types.h>
 9 #include <sys/stat.h>
10 #include <pthread.h>
11 char date[255];
12 char startLoc[255];
13
14
15 int findafterdate(int pid, char startLocation);
16
17
18
19 int main(int argc, char* argv[]){
20     //check arguments have been used
21
22     if(argc <2){
23         fprintf(stderr, "ERROR -- no argument set. use -h for help\n");
24         exit(EXIT_FAILURE);
25     }
26
27     //check for help switch
28     if (strcmp(argv[1], "-h")==0){
29         printf("usage: %s -t \"YYYY-MM-DD hh:mm:ss\"\n", argv[0]);
30         exit(EXIT_SUCCESS);
31     }
32     //check for cutoff time switch
33     else if(strcmp(argv[1], "-t")==0){
34       //check correct argument was used
35       if (argc <= 2){
36          fprintf(stderr, "ERROR -- use the format: %s -t \"YYYY-MM-DD hh:mm:ss\"\n", argv[0]);
37          exit(EXIT_FAILURE);
38       }
39       //set global variable startLoc to argv[3], or "." if none has been given
40       if (argc <= 3){
41         printf("test");
42         strncpy(startLoc, ".", sizeof(startLoc));
43         printf("start location automatically set to launch directory\n");
44       }
45       else{
46         printf("test");
47         strncpy(startLoc, argv[3], sizeof(startLoc));
48         printf("start location set to %s\n", startLoc);
49       }
50       //check if a filename was given
51
52       if ((strncmp(argv[2], "2", 1)!=0)){
53         printf("filename identified\n");
54         struct stat filestat;
55         stat(("%s", argv[2]), &filestat);
56         printf("%s", ctime(&filestat.st_mtime));
57         strncpy(date, ("%s", ctime(&filestat.st_mtime)), sizeof(date));
58         pid_t pid;
59         pid = fork();
60         findafterdate(pid, *startLoc);
61         return 0;
62       }
63
64       //check length of string to determine whether correct YYYY-MM-DD hh:mm:ss format was used
65       else if (strlen(argv[2]) <16 || strlen(argv[2])>19){
66         fprintf(stderr, "ERROR -- Invalid date format\n");
67         exit(EXIT_FAILURE);
68       }
69       //re - format argument into tm
70       struct tm tm;
71
72       memset(&tm, 0, sizeof(struct tm));
73       strptime(argv[2], "%Y-%m-%d %H:%M:%S", &tm);
74       strftime(date, sizeof(date), "%b %d %Y %H:%M", &tm);
75       pid_t pid;
76       pid = fork();
77       findafterdate(pid, *startLoc);
78       return 0;
79     }
80 }
81 int findafterdate(int pid, char startLocation){
82     if (pid==0){
83 //      printf("child check");
84         printf("start location: %s || date : %s\n", startLocation, date);
85         execl("/usr/bin/find", "find",("%s", startLocation), "-newermt", ("%s", date), NULL);
86     }
87     else{
88         printf("listing files modified after: %s\n", date);
89         int status;
90         waitpid(pid, &status, 0);
91     }
92     return EXIT_SUCCESS;
93   }
                                                                                                                                                                                             62,2-5        Bot

Дочерний процесс должен напечатать «дочернюю проверку» (это было добавлено, чтобы убедиться, что во время фактического процесса он не произошел сбой сегмента) перед выполнением «find -newermt», чтобы показать все файлы в начальном каталоге, которые были изменены после датыдано.Вместо этого он просто ничего не делает.Я не могу понять, почему это так.

1 Ответ

0 голосов
/ 29 декабря 2018

В findafterdate(), startLocation является char, но передается в printf() в качестве аргумента, соответствующего дескриптору формата %s, где ожидается char *.Компилятор должен был предупредить вас об этом;попробуйте скомпилировать с включенными предупреждениями.Как следствие, поведение программы не определено.

Неопределенное поведение не определено, ничего нельзя сказать о работе программы.

PS Призыв кexecl() очень странно.Как вы думаете, что ("%s", startLocation) означает, что отличается от простого startLocation?И аргументы execl() должны быть char *, а не char.

...