linux下多进程编程 pdf,Linux下的多进程编程初步(转载).pdf

本文介绍了Linux环境下多进程编程的基础知识,包括进程的结构、fork函数创建新进程以及exec函数替换当前进程。通过示例代码展示了fork如何在程序中创建子进程,并阐述了父子进程之间的数据独立性。此外,还简要提到了进程控制中的其他函数,如vfork。
摘要由CSDN通过智能技术生成

Linux下的多进程编程初步(转载)

1 引言

对于没有接触过Unix/Linux操作系统的人来说 ,fork是最难理解的概念之一 :它执行一次却返回两个值。

fork函数是Unix系统最杰出的成就之一 ,它是七十年代UNIX早期的开发者经过长期在理论和实践上的艰苦探索

后取得的成果 ,一方面 ,它使操作系统在进程管理上付出了最小的代价 ,另一方面 ,又为程序员提供了一个简

洁明了的多进程方法。与DOS和早期的Windows不同,Unix/Linux系统是真正实现多任务操作的系统 ,可以

说 ,不使用多进程编程 ,就不能算是真正的Linux环境下编程。

多线程程序设计的概念早在六十年代就被提出,但直到八十年代中期 ,Unix系统中才引入多线程机制 ,

如今 ,由于自身的许多优点 ,多线程编程已经得到了广泛的应用。

下面 ,我们将介绍在Linux下编写多进程和多线程程序的一些初步知识。

2 多进程编程

什么是一个进程?进程这个概念是针对系统而不是针对用户的 ,对用户来说 ,他面对的概念是程序。当

用户敲入命令执行一个程序的时候 ,对系统而言 ,它将启动一个进程。但和程序不同的是 ,在这个进程中,系

统可能需要再启动一个或多个进程来完成独立的多个任务。多进程编程的主要内容包括进程控制和进程间通

信 ,在了解这些之前 ,我们先要简单知道进程的结构。

2.1 Linux下进程的结构

Linux下一个进程在内存里有三部分的数据 ,就是"代码段"、"堆栈段"和"数据段"。其实学过汇编语言的人

一定知道 ,一般的CPU都有上述三种段寄存器 ,以方便操作系统的运行。这三个部分也是构成一个完整的执行

序列的必要的部分。

"代码段" ,顾名思义 ,就是存放了程序代码的数据 ,假如机器中有数个进程运行相同的一个程序 ,那么它

们就可以使用相同的代码段。"堆栈段"存放的就是子程序的返回地址、子程序的参数以及程序的局部变量。而

数据段则存放程序的全局变量 ,常数以及动态数据分配的数据空间(比如用malloc之类的函数取得的空间)。

这其中有许多细节问题 ,这里限于篇幅就不多介绍了。系统如果同时运行数个相同的程序 ,它们之间就不能使

用同一个堆栈段和数据段。

2.2 Linux下的进程控制

在传统的Unix环境下 ,有两个基本的操作用于创建和修改进程 :函数fork( )用来创建一个新的进程 ,该进

程几乎是当前进程的一个完全拷贝;函数族exec( )用来启动另外的进程以取代当前运行的进程。Linux的进程

控制和传统的Unix进程控制基本一致 ,只在一些细节的地方有些区别 ,例如在Linux系统中调用vfork和fork完

全相同,而在有些版本的Unix系统中,vfork调用有不同的功能。由于这些差别几乎不影响我们大多数的编程 ,

在这里我们不予考虑。

2.2.1 fork( )

fork在英文中是"分叉"的意思。为什么取这个名字呢?因为一个进程在运行中,如果使用了fork ,就产生

了另一个进程 ,于是进程就"分叉"了,所以这个名字取得很形象。下面就看看如何具体使用fork ,这段程序演

示了使用fork的基本框架 :

[cpp]

01.  void main(){

02.  int i;

03.  if ( fork()   0 ) {

04.  /* 子进程程序 */

05.  for ( i   1; i <1000; i ++ ) printf("This is child process/n");

06.  }

07.  else {

08.  /* 父进程程序*/

09.  for ( i   1; i <1000; i ++ ) printf("This is process process/n");

10.  }

11.  }

程序运行后 ,你就能看到屏幕上交替出现子进程与父进程各打印出的一千条信息了。如果程序还在运行

中,你用ps命令就能看到系统中有两个它在运行了。

那么调用这个fork函数时发生了什么呢?fork函数启动一个新的进程 ,前面我们说过 ,这个进程几乎是当

前进程的一个拷贝 :子进程和父进程使用相同的代码段 ;子进程复制父进程的堆栈段和数据段。这样 ,父进程

的所有数据都可以留给子进程 ,但是 ,子进程一旦开始运行 ,虽然它继承了父进程的一切数据 ,但实际上数据

却已经分开 ,相互之间不再有影响了,也就是说 ,它们之间不再共

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
前台: (1)注册登录模块:按照学校的相关规定进行注册和登录。 (2)招聘信息查看:高校毕业生们可以网站首页上查看所有的招聘信息,除此之外还可以输入公司名称或岗位名称进行搜索。 (3)用人单位模块:此模块为宣传用人单位的主要功能模块,具体包括用人单位简介、岗位需求及职责及公司介绍等功能。 (4)就业指导:学生朋友们在就业前可以通过此模块获取指导。 (5)新闻信息:为了让用户们可以了解到最新的新闻动态,本系统可以通过新闻信息查看功能阅读近期的新闻动态。 (6)在线论坛:毕业季的同学们可以通过此模块相互交流。 后台: (1)系统用户管理模块:可以查看系统内的管理员信息并进行维护。 (2)学生管理模块:通过此功能可以添加学生用户,还可以对学生信息进行修改和删除。 (3)用人单位管理模块:管理员用户通过此模块可以管理用人单位的信息,还可以对用人单位信息进行查看和维护。 (4)招聘管理模块:管理员通过此功能发布和维护系统内的照片信息。 (5)就业指导管理模块:通过此模块可以编辑和发布就业指导信息,从而更好的帮助就业季的同学们。 (6)论坛管理:通过论坛管理可以查看论坛中的主题帖及里面的回复信息,除此之外还可以对论坛中的信息进行维护和管理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值