linux 互斥量 数量限制(linux 互斥量)-冯金伟博客园

Linux下进程的创建与进程间通信?

代码示例:

#include <stdio.h>

#include <unistd.h>

#include <fcntl.h>

#define READ_TERMINAL 0

#define WRITE_TERMINAL 1

int main() {

int file_descriptors;

pid_t pid_f;

char PipeBuf={‘a’,‘0’};

int read_ret=0;

pipe(file_descriptors);

pid_f=fork();

if (pid_f<0)

{

printf(“fork error!n”);

exit(1);

}

else if (pid_f==0)

{

//子进程向父进程发一则消息

printf(“Write in Pipe To FatherProcess!n”);

close(file_descriptors);

sleep(1);

write(file_descriptors,“Child Send”,sizeof(“Child Send”));

//open(file_descriptors);

}

else

{

//父进程接收(读取)消息

printf(“Read in Pipe From ChildProcess!n”);

//通过fcntl()修改为使得读管道数据具有非阻塞的特性

int flag=fcntl(file_descriptors,F_GETFL,0);

flag |= O_NONBLOCK;

if(fcntl(file_descriptors,F_SETFL,flag) < 0){

perror(“fcntl”);

exit(1);

}

close(file_descriptors);

read_ret=read(file_descriptors,PipeBuf,sizeof(PipeBuf));//没阻塞的读

printf(“Read Message are : %sn”,PipeBuf);

linux实现共享内存同步有哪些方法?

共享内存可以说是最有用的进程间通信方式,也是最快的IPC形式。两个不同进程A、B共享内存的意思是,同一块物理内存被映射到进程A、B各自的进程地址空间。

进程A可以即时看到进程B对共享内存中数据的更新,反之亦然。由于多个进程共享同一块内存区域,必然需要某种同步机制,互斥锁和信号量都可以。

采用共享内存通信的一个显而易见的好处是效率高,因为进程可以直接读写内存,而不需要任何数据的拷贝。

对于像管道和消息队列等通信方式,则需要在内核和用户空间进行四次的数据拷贝,