课件与实验-进程操作_第1页
课件与实验-进程操作_第2页
课件与实验-进程操作_第3页
课件与实验-进程操作_第4页
课件与实验-进程操作_第5页
已阅读5页,还剩10页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

进程操作进程创建父进程创建若干子进程;后者再创建其子进程;与此类推,构成了反映“传承”关系的一棵进程树子进程的资源子进程共享父进程的所有资源子进程共享父进程的部分资源子进程不从父进程共享资源,重新独立申请执行代码的执行顺序父进程和子进程并发执行父进程在子进程执行期间等待,待子进程执行完毕后才恢复执行余下代码进程创建

(Cont.)地址空间中的image子进程复制了(duplicate,不是copy)父进程的image子进程全新装入一个程序,得到不同于父进程的image举例:UNIX的进程创建fork系统调用创建一个新(子)进程fork之后,exec系统调用装入一个新程序Unix环境里创建子进程Unix环境fork一个进程int

main(){Pid_t

pid;/*

fork

another

process

*/pid

=

fork();if

(pid

<

0)

{

/*

error

occurred

*/fprintf(stderr,

"Fork

Failed");exit(-1);}else

if

(pid

==

0)

{

/*

child

process

*/execlp("/bin/ls",

"ls",

NULL);}else

{

/*

parent

process

*//*

parent

will

wait

for

the

child

to

complete

*/wait

(NULL);printf

("Child

Complete");exit(0);}}Solaris系统中常见的一棵进程树进程终止“进程终止”语义之一:子进程执行完最后一条指令后,要求操作系统将自己杀出(exit)。语义动作含:子进程传递数据给父进程(通过父进程的wait操作)子进程的资源被操作系统收回“进程终止”语义之二:父进程终止子进程的执行

(abort)。终止原因可能是:子进程超额使用系统资源早前交给子进程执行的任务,过期无效了如果父进程终止了,它的子进程怎么办?有些操作系统把这些子进程也全部终止All

children

terminated

-

cascadingtermination进程间合作独立进程不会影响其它进程的执行,也不被影响合作进程影响其它进程,或者受其影响进程间合作是必须的,带来的好处:共享信息加速(计算)执行任务模块化方便调用,等等……经典案例:生产者-消费者问题生产者进程“生产”出信息,存储在缓冲区,供消费者进程“消费”unbounded-buffer

缓冲区的容量无限bounded-buffer缓冲区的容量有限P0P1inoutBounded-Buffer

“共享内存”解决方案数据结构#define

BUFFER_SIZE

10Typedef

struct

{.

.

.}

item;item

buffer[BUFFER_SIZE];int

in

=

0;int

out

=

0;解决方案可行但是只能用足BUFFER_SIZE-1个缓冲单元Bounded-Buffer

生产者进程的“存”while

(true)

{/*

Produce

an

item

*/while

(((in

=

(in

+

1)

%

BUFFER

SIZEcount)==

out); /*

do

nothing

--

no

free

buffers

*/buffer[in]

=

item;in

=

(in

+

1)

%

BUFFER

SIZE;{Bounded

Buffer

消费者进程的“取”while

(true)

{while

(in

==

out);

//

do

nothing

--

nothing

toconsume//

remove

an

item

from

the

bufferitem

=

buffer[out];out

=

(out

+

1)

%

BUFFER

SIZE;return

item;{Interprocess

Communication

(IPC)进程间通信IPC,提供一套进程通信、进程同步的机制消息系统–进程间相互通信的途径,不需要有共享变量的介入IPC机制有2个最基本的进程操作:send(message)receive(message)变种:Direct

Communicationsend

(P,message)–直接发消息给进程Preceive(Q,message)–直接接收来自进程Q的消息变种:Indirect

Communicationsend(A,message)–发送消息给邮件服务器Areceive(A,message)–从邮件服务器A接收消息同步通信

vs

异步通信同步通信发送操作send:发送进程等待,直至接收进程确认收到消

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论