linux多进程框架
来源:互联网 发布:长城证券软件下载 编辑:程序博客网 时间:2024/06/03 19:30
"helo world "
这是我第一次开始书写关于一些技术类的文章,新手前来报道请多多指教。告别过去,重新的人生,起航。
话不多说,第一篇是关于linux下多进程通信用到的比较简单但却不得不用到的代码段,自己姑且将其定义为多进程框架吧,方便以后会用到,对我自己来说,linux最诱人的地
方就在于高级编程这一块,比如多进程通信,多线程,和网络编程,日常的小项目中也经常会用的到,所以就感觉这一块也比较重要。
linux中创建进程唯一的一个函数函数就是 fork(),除了init进程不是用fork创建的其余的进程都是通过它来创建的,下面就贴上关于进程创建的最小框架。
#include <unistd.h>
#include <stdio.h>
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多进程框架
- linux下的多进程服务器框架
- linux 进程调度器框架
- 多进程框架
- 多进程框架
- 多进程浏览器框架
- linux进程调度器(__schedule)框架
- Linux进程控制编程知识框架梳理
- C++多进程并发框架
- C++多进程并发框架
- C++多进程并发框架
- C++多进程并发框架
- C++多进程并发框架
- linux多进程编程
- Linux多进程相关内容
- linux 多进程编程
- linux多进程调试
- linux GTK 多进程
- 学Android--文件存储
- Kanzi学习之路(6):属性绑定
- 用python做自动化测试--数据库的自动化测试(2)
- hdu 4118 Holiday's Accommodation 树形dp
- 谷歌新发布的分布式数据库服务,是要打破CAP定理了吗?
- linux多进程框架
- task_struct结构体所有成员用法
- android 步骤指示器实现
- Linux 下的一个全新的性能测量和调式诊断工具 Systemtap
- [POJ]3299-Humidex[初投稿]
- [Kotlin&Anko开发Android入门学习笔记]-01使用Kotlin创建Activity活动
- ArcGIS Engine程序开发之 IToolbarMenu.AddItem()函数中的参数
- SpringMVC Resource interpreted as Script but transferred with MIME type application/octet-stream:
- 数位dp入门详解