父进程中调用fork返回的是新子进程的PID。新进程将继续执行,就象原进程一样,只不过在子进程里调用fork将返回 0 #include
#include
#include
#include
#include
int main() { pid_t pid; char * message; int n; int exit_code; printf("fork program starting!/n"); pid = fork(); switch(pid) { case -1: perror("fork failed!/n"); exit( 1 ); case 0: message = "this is the child!/n"; printf("pid = %d/n",pid); n = 5; exit_code = 37; break; default: message = "this is parent!/n"; printf("pid = %d/n",pid); n = 3; exit_code = 0; break; } for(; n > 0; n--) { puts(message); sleep(1); } if(pid != 0) { int stat_val; pid_t child_pid; child_pid = wait(&stat_val); printf("child has finished: PID = %d/n",child_pid); if( WIFEXITED(stat_val) ) { printf( "Child exited with code: %d/n", WEXITSTATUS(stat_val) ); } else { printf("Child terminated abnormally!/n"); } } exit(exit_code); } 程序在调用fork的时候被分成两个独立的进程,程序根据fork的非零返回直确定父进程,父进程设置了一个消息输出次数,两次输出之间间隔一秒 fork方法是以个单调用双返回的函数。 在父进程中返回的是该创建的子进程的进程标识号 在子进程中返回的是0, 创建不成工,返回-1 反正够绕的,多作,多想,多动手理解就好了
linux编程笔记,进程简单例子
最新推荐文章于 2025-01-13 20:45:01 发布