Linux进程

xiaoxiao2021-02-28  60

学习进程创建, 等待, 终止. 使用代码实现.

//系统调用创建进程

#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直接退掉.

return会调用局部对象的析构函数,exit不会.
转载请注明原文地址: https://www.6miu.com/read-2622831.html

最新回复(0)