Linux多任务多线程编程-.ppt
文本预览下载声明
* 从父进程到子进程的管道 * 对管道的操作 如果要直接存取管道,可以使用和低级的文件I / O同样的系统调用,因为在系统内核中管道实际上是由一个有效的索引节点表示的。 如果希望向管道中发送数据,可以使用系统调用write( ),反之,如果希望从管道中读取数据,可以使用系统调用read( )。 * 创建管道 pipe 如果要使用C语言创建一个简单的管道,可以使用系统调用pipe( )。 #include unistd.h 原型:int pipe( int fd[2] ); 其中fd[0]为读打开,fd[1]为写打开; 返回值:如果系统调用成功,返回0 如果系统调用失败返回- 1 * 管道的通信实现 #include sys/types.h #include unistd.h #include stdio.h #include stdlib.h #include string.h int main() { int fd[2]; pid_t pid; char buf[64] = Im parent process!\n; // 父进程要写入管道的信息 char line[64]; if (0!=pipe(fd)) { // 创建管道并检查结果 fprintf(stderr, Fail to create pipe!\n); return 0; } } pid = fork(); // 创建进程 if (pid0) { fprintf(stderr, Fail to create process!\n); return 0; } else if (0==pid) { // 父进程 close(fd[0]); // 关闭读管道,使得父进程只能向管道写入数据 write(fd[1], buf, strlen(buf)); // 写数据到管道 close(fd[1]); // 关闭写管道 } else { // 子进程 close(fd[1]); // 关闭写管道,使得子进程只能从管道读取数据 read(fd[0], line, 64); // 从管道读取数据 printf(DATA From Parent: %s, line); close(fd[0]); // 关闭读管道 } return 0; 父进程关闭读管道,子进程关闭写管道,管道变成了一个从父进程到子进程单向传递的数据的通道。 * b.共享内存方法 共享内存:在内存开辟一段空间,供不同的进程访问。与管道相比,共享内存不能在多个不同进程间共享数据,而且可以比管道传送更大量的数据。 * 共享存储 共享存储允许两个或多个进程共享一给定的存储区。 因为数据不需要在客户机和服务器之间复制,所以这是最快的一种IPC。 使用共享存储的唯一窍门是多个进程之间对一给定存储区的同步存取。 通常,信号量被用来实现对共享存储存取的同步。 * shmget shmget,它获得一个共享存储标识符 #include sys/types.h #include sys/ipc.h #include sys/shm.h int shmget(key_t key, int size, int flag) ; Key:关键字是系统唯一关键字,由ftok()生成,亦可指定; Size:需要的共享内存的字节数; Flag:存储操作方式,读,写,创建通信.. 返回:若成功则为共享内存I D,若出错则为- 1 * shmat 一旦创建了一个共享存储段,进程就可调用shmat将其连接到它的地址空间中. Shmat()是获得共享内存的起始地址. #include sys/types.h #include sys/ipc.h #include sys/shm.h void *shmat(int shmid, void *addr, int flag) ; Shmid:共享内存的ID,由shmget产生,addr:指定共享内存地 址,若为0,表示由系统指定共享内存地址,若获取内存成功, 则返回相应共享内存的地址. 返回:若成功则为指向共享存储段的指针,若出错则为- 1 * shmdt 当对共享存储段的操作已经结束时,则调用shmdt脱接该段。 #include sys/types.h #include sys/ipc.h #include sys/shm.h int shmdt(void * a d d r) ; a d d r:要分离共享内存
显示全部