学习进程创建, 等待, 终止. 使用代码实现.
//系统调用创建进程
#include<stdio.h>
#include<sys/types.h>
#include<unistd.h>
int main()
{
int ret=fork();
printf("hello proc:%d!,ret:%d\n",getpid(),ret);
sleep(1);
return 0;
}
//等待终止
#include<stdio.h>
#include<stdlib.h>
int main()
{
pid_t id=fork();
if(id<0)
{
perror("fork");
return 1;
}
else if(id>0)
{
printf("parent[%d] is sleeping...\n",getpid());
sleep(30);
}
else
{
printf("child[%d] is begin Z...\n",getpid());
sleep(5);
exit(EXIT_SUCCESS);
}
return 0;
}
调研popen/system, 理解这两个函数和fork的区别.
//popen
#include <stdio.h> #include <stdlib.h> void main( void ) { char psBuffer[128]; FILE *chkdsk; if( (chkdsk = _popen( "dir *.c /on /p", "rt" )) == NULL ) exit( 1 ); while( !feof( chkdsk ) ) {
if( fgets( psBuffer, 128, chkdsk ) != NULL ) printf( psBuffer ); } printf( "\nProcess returned %d\n", _pclose( chkdsk ) ); }
//system
#include <process.h> void main( void ) { system( "type system.c" ); }
调研vfork创建的子进程, 直接return为什么会出现崩溃
#include #include #include intmain(void) { intvar; var = 88; if((pid = vfork()) < 0) { printf("vfork error"); exit(-1); } elseif(pid == 0) { /* 子进程 */ var++; return0; } printf("pid=%d, glob=%d, var=%d\n", getpid(), glob, var); return0; }
- vfork是 创建一个子进程,并和父进程的内存数据share一起用。
vfork是这样的工作的,
1)保证子进程先执行。
2)当子进程调用exit()或exec()后,父进程往下执行。
return会释放局部变量,并弹栈,回到上级函数执行。exit直接退掉.