linux多进程编程 详细讲解

linux多进程编程 详细讲解

ID:11383536

大小:756.65 KB

页数:22页

时间:2018-07-11

linux多进程编程 详细讲解_第1页
linux多进程编程 详细讲解_第2页
linux多进程编程 详细讲解_第3页
linux多进程编程 详细讲解_第4页
linux多进程编程 详细讲解_第5页
资源描述:

《linux多进程编程 详细讲解》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、Linux多进程编程主要内容LINUX进程介绍1Linux多进程编程2Linux多进程通讯3多进程实例4LINUX进程介绍什么是进程简单地说就是允许起来的程序,即应用程序的运行实例。进程这个概念是针对系统而不是针对用户的,对用户来说,他面对的概念是程序。当用户敲入命令执行一个程序的时候,对系统而言,它将启动一个进程。但和程序不同的是,在这个进程中,系统可能需要再启动一个或多个进程来完成独立的多个任务。LINUX进程介绍进程ID唯一标识进程的非负整形变量,pid。init进程内核自举启动后运行的第一个进程,/etc/inittab是它启动

2、的配置文件,所有的孤儿进程的父进程为init。LINUX进程介绍进程的结构Linux下一个进程在内存里有三部分的数据,就是"代码段"、"堆栈段"和"数据段"。其实学过汇编语言的人一定知道,一般的CPU都有上述三种段寄存器,以方便操作系统的运行。这三个部分也是构成一个完整的执行序列的必要的部分。LINUX进程介绍进程的结构"代码段",顾名思义,就是存放了程序代码的数据,假如机器中有数个进程运行相同的一个程序,那么它们就可以使用相同的代码段。"堆栈段"存放的就是子程序的返回地址、子程序的参数以及程序的局部变量。系统如果同时运行数个相同的程序

3、,它们之间就不能使用同一个堆栈段和数据段。LINUX进程介绍进程的优点对不同进程来说,它们具有独立的数据空间、代码空间和堆栈空间。因此,相比于线程而言,进程有更好的健壮性。LINUX进程介绍进程带来的问题由于不共享数据段,进程相比于线程而言,各个进程间的通讯比较麻烦。必须依靠信号量、管道、共享内存和socket等方式进行通讯。并且,进程的开销也远远大于线程。LINUX多进程编程forkfork函数是Unix系统最杰出的成就之一,它是七十年代UNIX早期的开发者经过长期在理论和实践上的艰苦探索后取得的成果,一方面,它使操作系统在进程管理上

4、付出了最小的代价,另一方面,又为程序员提供了一个简洁明了的多进程方法。LINUX多进程编程Linux下的fork这个函数名是英文中“分叉”的意思。为什么取这个名字呢?因为一个进程在运行中,如果使用了fork,就产生了另一个进程,于是进程就“分叉”了,所以这个名字取得很形象。它的返回值为:如果在父进程中返回子进程的pid,如果是在子进程中则返回0。LINUX多进程编程Linux下的fork当fork函数执行完毕后,内核并不会马上复制父进程的堆、栈和数据段到子进程,而是采用COW技术,使两者的这些内容变为只读共享,一旦其中一个进程内改变了某

5、页内容,那么就进行复制该页。Linux多进程编程fork创建子进程getpid获取进程pidgetuid、geteuid、setuid、setreuid、setfsuidgetgid、getegid、setgid、setregid、getfsgidLINUX多进程编程voidmain(intac,char*av[]){inti;if(fork()==0){/*子进程程序*/for(i=1;i<1000;i++)printf("Thisischildprocess");} else{/*父进程程序*/for(i=1;i<1000;i++)

6、printf("Thisisprocessprocess");}  }LINUX多进程编程voidmain(){  for(;;)fork();}可以预先给每个用户设置可运行的最大进程数,这样,只要不是root,任何能运行的进程数也许不足系统总的能运行和进程数的十分之一,这样,就能对付上述恶意的程序了。LINUX多进程编程intmain(intac,char*av[]){intGID=100,UID=100;if(-1==setfsgid(GID))return-2;if(-1==setgid(GID))return-3;if(-1==

7、setregid(GID,GID))return-4;if(-1==setfsuid(UID))return-5;if(-1==setuid(UID))return-6;if(-1==setreuid(UID,UID))return-7;return0;}LINUX多进程通讯信号本质信号是在软件层次上对中断机制的一种模拟,在原理上,一个进程收到一个信号与处理器收到一个中断请求可以说是一样的。信号是异步的,一个进程不必通过任何操作来等待信号的到达,事实上,进程也不知道信号到底什么时候到达。信号是进程间通信机制中唯一的异步通信机制,可以看作

8、是异步通知,通知接收信号的进程有哪些事情发生了。信号机制经过POSIX实时扩展后,功能更加强大,除了基本通知功能外,还可以传递附加信息。但这里意义不是很大,往往需要数据的交换我们使用的是进程间其他通讯方法。

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。