僵尸进程wait()waitpid().pptVIP

  1. 1、本文档共8页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
僵尸进程wait()waitpid().ppt

僵尸进程 wait() waitpid() 对于进程的一生可以用一些形象的比喻作一个小小的总结:? 随着一句fork,一个新进程呱呱落地,但它这时只是老进程的一个克隆。离家独立,开始了为人民服务的然后随着exec,新进程脱胎换骨,职业生涯。 ? 人有生老病死,进程也一样,它可以是自然死亡,即运行到main函数的最后一个”}”,从容地离我们而去;也可以是自杀,自杀有2种方式,一种是调用 exit函数,一种是在main函数内使用return,无论哪一种方式,它都可以留下遗书,放在返回值里保留下来;它还甚至能可被谋杀,被其它进程通过 另外一些方式结束他的生命。? 进程死掉以后,会留下一具僵尸,wait和waitpid充当了殓尸工,把僵尸推去火化,使其最终归于无形。 /developerworks/cn/linux/kernel/syscall/part3/index.html Problems 程序与截图不一致 程序发生明显错误 if( (pid=fork()==0) ) if( kill(id1,SIGINT) ) //杀死进程1 printf(子进程1被父进程杀死......\n); 临界资源(偶说过了,只是copy而已) 创建信号量集 不能单独定义一个信号量,而只能定义一个信号量集,其中包括一组信号量,同一信号量集中的信号量使用同一引用ID,这样设置是为了多个资源或同步操作的需要。 semget(IPC_PRIVATE,1,0600); 无论何时创建IPC结构,都应制定一个键,键的数据类型是基本系统数据类型key_t,通常在头文件sys/types.h中被定义为长整型。键由内核变换成标识符。 IPC_PRIVATE可用于父子进程关系。父进程指定IPC_PRIVATE创建一个新IPC结构,所返回的标识符在调用fork后可由子进程使用。 Flag说明的是读、写权限(ugo,1、2、4)。 赋初值 semctl(semid,0,SETVAL,arg); semnum指定该信号量集合中的一个信号量成员。semnum在[0,nsems-1]间。 cmd参数是指定的10种命令的一种,常用SETVAL设置成员semnum的semval值,该值由arg.val指定。 arg参数是可选的,若使用,其类型为union semun(注意头文件linux/sem.h、linux/ipc.h) 操作信号量 Semop(semid,struct sembuf *,1); nsops:信号操作结构的数量,恒大于或等于1。 Sem_flg一般设为SEM_UNDO 存储映射 如果进程是相关的,可按如下调用mmap mmap(0,size,PROT_READ|PROT_WRITE,MAP_ANON|MAP_SHARED,-1,0) 返回值:若成功则返回映射区的起始地址,若出错则返回MAP_FAILED 进程终止时,或调用了munmap之后,存储映射区就被自动解除映射 注意事项 不要忘记fork出来的进程只是copy而已,所以要对同一个变量进行操作时,记得利用公共存储池。 以下两个semWait,semSignal函数供参考 void semWait(int sem_id){ struct sembuf sem_buff; sem_buff.sem_num=0; sem_buff.sem_op=-1; sem_buff.sem_flg=SEM_UNDO; semop(sem_id,sem_buff,1); } void semSignal(int sem_id){ struct sembuf sem_buff; sem_buff.sem_num=0; sem_buff.sem_op=1; sem_buff.sem_flg=SEM_UNDO; semop(sem_id,sem_buff,1); } * *

文档评论(0)

139****2640 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档