Я работаю над упражнением в учебнике "Концепции операционной системы 7-го издания", и я немного смущен тем, как работает fork()
. По моему мнению, fork()
создает дочерний процесс, который запускается одновременно с его родителем. Но тогда, как мы точно знаем, какой процесс запускается первым? Я имел в виду порядок исполнения.
Проблема
Напишите программу C с помощью системного вызоваfork()
, который генерирует последовательность Фибоначчи в дочернем процессе. Номер последовательности будет указан в командной строке.
Это мое решение:
#include <sys/types.h>
#include <stdlib.h>
#include <stdio.h>
#include <unistd.h>
void display_fibonacci_sequence( int n ) {
int i = 0;
int a = 1;
int b = 1;
int value;
printf( "%d, %d, ", a, b );
for( ;i < n - 2; ++i ) {
value = a + b;
printf( "%d, ", value );
a = b;
b = value;
}
printf( "\n" );
}
int main( int argc, char** argv ) {
int n;
pid_t pid;
pid = fork();
if( argc != 2 ) {
fprintf( stderr, "Invalid arguments" );
exit( -1 );
}
n = atoi( argv[1] );
if( pid < 0 ) {
fprintf( stderr, "Fork failed" );
exit( -1 );
}
else if( pid == 0 ) {
display_fibonacci_sequence( n );
}
else { // parent process
// what do we need to do here?
}
}
Честно говоря, я не вижу разницы между использованием fork
и не использованием fork
. Кроме того, если я хочу, чтобы родительский процесс обрабатывал входные данные от пользователя, и пусть дочерний процесс обрабатывает отображение, как я могу это сделать?