- 11
- 0
- 约2.76万字
- 约 28页
- 2018-06-09 发布于河南
- 举报
第十三章_C语言多进程编程
一.多进程程序的特点 由于UNIX系统是分时多用户系统, CPU按时间片分配给各个用户使用,而在实质上应该 说CPU按时间片分配给各个进程使用,每个进程都有自己的运行环境以使得在CPU做进程 切换时不会忘记该进程已计算了一半的半成??. 以DOS的概念来说, 进程的切换都 是一次DOS中断处理过程, 包括三个层次: (1)用户数据的保存: 包括正文段(TEXT), 数据段(DATA,BSS), 栈段(STACK), 共享内存段(SHARED MEMORY)的保存. (2)寄存器数据的保存: 包括PC(program counter,指向下一条要执行的指 令的地址), PSW(processor status word,处理机状态字), SP(stack pointer,栈指针), PCBP(pointer of process control block,进程控制块指针), FP(frame pointer,指向栈中一个函数的local变量的首地址), AP(augument pointer,指向栈中函数调用的实参位置), ISP(interrupt stack pointer,中断栈指针), 以及其他的通用寄存器等. (3)系统层次的保存: 包括proc,u,虚拟存储空间管理表格,中断处理栈.以便于该进程再一次得到CPU时间片时 能正常运? 既然系统已经处理好所有这些中断处理的过程, 我们做程序还有什么要担心 的呢? 我们尽可以使用系统提供的多进程的特点, 让几个程序精诚合作, 简单而又高效地把结果给它搞出来. 另外,UNIX系统本身也是用C语言写的多进程程序,多进程编程是UNIX的特点,当我们熟悉 了多进程?将会对UNIX系统机制有一个较深的认识.首先我介绍一下多进程程序的一些突 出的特点: 1.并行化 一件复杂的事件是可以分解成若干个简单事件来解决的, 这在程序员 的大脑中早就形成了这种概念, 首先将问题分解成一个个小问题, 将小问 题再细分, 最后在一个合适的规模上做成一个函数. 在软件工程中也是这 么说的. 如果我们以图的方式来思考, 一些小问题的计算是可以互不干扰 的, 可以同时处理, 而在关键点则需要统一在一个地方来处理, 这样程序 的运行就是并行的, 至少从人的时间观念上来说是这样的. 而每个小问题 的计算又是较简单的. 2.简单有序 这样的程序对程序员来说不亚于管理一班人, 程序员为每个进程设计 好相应的功能, 并通过一定的通讯机制将它们有机地结合在一起, 对每个 进程的设计是简单的, 只在总控部分小心应付(其实也是蛮简单的), 就可 完成整个程序的施工. 3.互不干扰 这个特点是操作系统的特点, 各个进程是独立的, 不会串位. 4.事务化 比如在一个数据电话查询系统中, 将程序设计成一个进程只处理一次 查询即可, 即完成一个事务. 当电话查询开始时, 产生这样一个进程对付 这次查询; 另一个电话进来时, 主控程序又产生一个这样的进程对付, 每 个进程完成查询任务后消失. 这样的编程多简单, 只要做一次查询的程序 就可以了. 二.常用的多进程编程的系统调用 1.fork() 功能:创建一个新的进程. 语法:#include unistd.h #include sys/types.h pid_t fork(); 说明:本系统调用产生一个新的进程, 叫子进程, 是调用进程的一个复 制品. 调用进程叫父进程, 子进程继承了父进程的几乎所有的属 性: . 实际UID,GID和有效UID,GID. . 环境变量. . 附加GID. . 调用exec()时的关闭标志. . UID设置模式比特位. . GID设置模式比特位. . 进程组号. . 会话ID. . 控制终端. . 当前工作目录. . 根目录. . 文件创建掩码UMASK. . 文件长度限制ULIMIT. . 预定值, 如优先级和任何其他的进程预定参数, 根据种类不同 决定是否可以继承. . 还有一些其它属性. 但子进程也有与父进程不同的属性: . 进程号, 子进程号不同与任何一个活动的进程组号. . 父进程号. . 子进程继承父进程的文件描述符或流时, 具有自己的一个拷贝 并且与父进程和其它子进程共享该资源. . 子进程的用户时间和系统时间被初始化为0. . 子进程的超时时钟设置为0. . 子进程的信号处理函数指针组置为空. . 子进程不继承父进程的记录锁. 返回值: 调用成功则对子进程返回0, 对父进程返回子进程号, 这也是 最方便的区分父子进程的方法. 若调用失败则返回-1给父进程, 子进程不生成.
您可能关注的文档
- 国际融资预结算 第八章.ppt
- 悬挑式外脚手架施工方案新.doc
- 法理学_复习资料.doc
- 合同法(公选课)修改2009.ppt
- 《经济法概论》第十六章:税法.ppt
- 财产清查具体方案1.doc
- 课程设计单片机实验指导书(学生版).doc
- 高佳敏四十二式太极拳_拳谱、图谱全集.doc
- ch04__数值计算 MATLAB.doc
- 单片机的多功能电子钟的课程设计.doc
- 《GB/T 21561.1-2025轨道交通 机车车辆 受电弓特性和试验 第1部分:机车车辆受电弓》.pdf
- 《GB/T 6346.2301-2025电子设备用固定电容器 第23-1部分:空白详细规范表面安装金属化聚萘二甲酸乙二醇酯膜介质直流固定电容器 评定水平EZ》.pdf
- 2026年中国城市建设史复习题200道含答案(基础题).docx
- 2026年注册会计师(CPA)考试题库200道及1套参考答案.docx
- 60103交通事故案卷文书 标准 ga 40-2018.pdf.pdf
- 小升初衔接第一讲:基础词汇与句型综合梳理与运用(基于Starters 14).docx
- 四级公路设计关键要素教学课件.pptx
- Unit7SectionA2a-2e课件鲁教版英语六年级下册.pptx
- 初中地理八年级:探秘台湾省环境与经济协同发展.docx
- Unit2Success单元重点单词单句写作练习课件-北师大版高中英语选择性(1).pptx
原创力文档

文档评论(0)