linux多进程框架

"helo world "

这是我第一次开始书写关于一些技术类的文章,新手前来报道请多多指教。告别过去,重新的人生,起航。

话不多说,第一篇是关于linux下多进程通信用到的比较简单但却不得不用到的代码段,自己姑且将其定义为多进程框架吧,方便以后会用到,对我自己来说,linux最诱人的地

方就在于高级编程这一块,比如多进程通信,多线程,和网络编程,日常的小项目中也经常会用的到,所以就感觉这一块也比较重要。

linux中创建进程唯一的一个函数函数就是 fork(),除了init进程不是用fork创建的其余的进程都是通过它来创建的,下面就贴上关于进程创建的最小框架。


#include
#include

int  main(int argc,char *argvp[])
{
pid_t res;
        res=fork();                            //开始创建一个进程
if(res<0)
  {
printf("fork failed\n");

return -1;
}
else if(res==0)
{
while(1)

{

printf("i am the child id: [%d]\n",getpid());

printf("my father's id:[%d]\n",getppid());

sleep(1);

//do the child 's thing.......

}
}

while(1)

{

printf("i am the father id:[%d]\n",getpid());

}

return 0;
}



fork()函数用来创建一个进程,此时程序会有两个返回值,

=0     - 表示子进程的返回值

>0     -表示父进程的返回值

进程在创建的时候做了很多的事情:


1.每个进程在fork时,内核会为其分配一个task_struct结构,称为进程描述符(PCB),

2.子进程将把父进程的大部分信息拷贝到自己的PCB中:

    如继承的东西有:

-文件描述符表

-当前工作目录

-控制终端

-内存信息

-进程相关标识

     没有继承的有:

-进程id 

-进程创建的时间

-子进程的未决信号被设置为空。

至此以后,两个进程就毫无关系了,但这个框架仅仅是在正常情况下子进程没有异常退出,如果考虑到有异常的发生,是需要考虑到回收子进程的PCB的,否则会出现僵尸进程,影响linux的执行效率解决的方法是使用信号机制,父进程等待子进程的SIGCHLD的信号,并使用wait()函数对其进行处理。






你可能感兴趣的:(linux高级编程)