Linux进程与线程通讯
报告人:
设计目的
1、深刻理解线程和进程的概念
2、掌握线程与进程在组成成分上的差别以及与其相适应的通讯方式和应用目标。设计的内容
1、以Linux系统进程和线程机制为背景,掌握fork()和clone()系统调用的
2、形式和功能以及与其相适应的高级通讯方式。由fork派生的子进程之间通过
pipe通讯,由clone创建的线程之间通过共享内存通讯,对于后者需要考虑互斥问题。
3、以生产者-消费者问题为例,通过实验理解fork()和clone()两个系统调用
的区别。程序要求能够创建4个进程或线程,其中包括两个生产者和两个消费者,生产者和消费者之间能够传递数据。
4、
三、设计准备
1、fork系统调用、
pid=fork()
创建一个子进程,子进程是父进程的完整复制,正常返回值为非负整数,对于父进程来说该数大于0,是子进程的编号(pid);对于子进程来说该数为0。正是利用反回值的差别可以决定二者不同的后继动作。
2、clone系统调用
int clone(int (*fn)(void * arg), void *stack, int flags, void * arg);
其中fn是轻进程所执行的函数,stack是轻进程所使用的栈,flag是CLONE_VM, CLONE_FS, CLONE_FILES, LONE_SIGHAND,CLONE_PID的组合,arg是调用过程的对应参数。Clone()的关键是flag的设定,CLONE_VM表示子进程共享父进程内存,CLONE_FS表示子进程共享父进程的文件系统,CLONE_SIGHAND表示子