- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
c语言-进程间通信资料
C语言-进程间通信 培训大纲 基础概念 进程产生的方式 进程间通信和同步 Linux下的线程 同步与互斥的概念 临界资源与临界区 临界资源:一段时间内仅允许一个进程使用的资源称为临界资源。 如:打印机、共享变量。 临界区:进程中访问临界资源的那段代码称为临界区,又称临界段。 同类临界区:所有与同一临界资源相关联的临界区。 同步与互斥 同步:多个相互合作的进程在一些关键点上可能需要互相等待或互相交换信息,这种相互制约关系称为进程同步。 互斥:当一个进程正在使用某资源时,其他希望使用该资源的进程必须等待,当该进程用完资源并释放后,才允许其他进程去访问此资源,我们称进程之间的这种相互制约关系为互斥。 信号量的定义 信号量由两个成员(s,q)组成,其中s是一个具有非负初值的整型变量,q是一个初始状态为空的队列。又称信号灯。 除信号量的初值外,信号量的值仅能由P操作(又称为wait操作)和V操作(又称为signal操作)改变。 信号量的物理含义 信号量中的整型变量S表示系统中某类资源的数目。 当其值大于0时,表示系统中当前可用资源的数目; 当其值小于0时,其绝对值表示系统中因请求该类资源而被阻塞的进程数目。 P操作 设S为一个信号量,P(S)执行时主要完成下述动作: S=S-1; if(S< 0) {设置进程状态为等待; 将进程放入信号量等待队列; 转调度程序;} V操作 V(S)执行时主要完成下述动作: S=S+1; if(S≤0){将信号量等待队列中的第一个进程移出; 设置其状态为就绪状态并插入就绪队列; 然后再返回原进程继续执行;} 注意 P操作可能阻塞执行进程,而V操作可以唤醒其他进程。 P、V操作在封锁中断的情况下执行,即一个进程在信号量上操作时,不会有别的进程同时修改该信号量。也就是说P、V操作是原语。 培训大纲 程序、进程和线程的概念 进程产生的方式 进程间通信和同步 Linux下的线程 进程号 每个进程在初始化的时候,系统都分配了一个ID号,用于标识此进程。在Linux中,进程号是唯一的,系统可以用这个值来表示一个进程,描述进程的ID号通常叫做PID,即进程ID(process id)。PID的变量类型是pid_t。 getpid()函数介绍 #include sys/types.h #include unistd.h pid_t getpid(); pid_t getppid(); 进程复制fork() 产生进程的方式比较多,fork()是其中的一种方式。fork()函数以父进程为蓝本复制一个进程,其ID号和父进程号不同。在Linux环境中,fork()是以写复制方式实现的,只有内存等与父进程不同,其它与父进程共享,只有在父进程或者子进程进行了修改后,才重新生成一份。 fork()函数介绍 fork()的原型如下,当成功时,fork()函数的返回值是进程的ID;失败则返回-1 #include sys/types.h #include unistd.h pid_t fork(void); fork()的特点是执行一次,返回两次。父进程和子进程中返回的是不同的值。父进程返回的是子进程的ID号,而子进程返回的是0。 system()方式 system()函数调用shell的外部命令在当前进程中开始另一个进程。 system()函数介绍 system()函数调用”/bin/sh-c command”执行特定的命令,阻塞当前进程直到command命令执行完毕。System()的原型如下: #include stdlib.h int system(const char * command); 执行system()函数时,会调用fork、execve、waitpid等函数,其中任意一个调用失败将导致system()函数调用失败。System()函数的返回值如下: 失败返回-1; 当sh不能执行时,返回127; 成功返回进程状态值; 进程执行exec 在使用fork()函数和system()函数的时候,系统中都会建立一个新的进程,执行调用者的操作,而原来的进程还会存在,直到用户显示的退出; 而exec()函数与之前的fork()和system()函数不同,exec()函数会用新进程代替原有的进程,系统会从新的进程运行,新的进程的PID值会与原来进程的PID值相同. exec()函数,其原型如
文档评论(0)