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对共享内存中数据的更新,反之亦然。由于多个进程共享同一块内存区域,必然需要某种同步机制,互斥锁和信号量都可以。
采用共享内存通信的一个显而易见的好处是效率高,因为进程可以直接读写内存,而不需要任何数据的拷贝。
对于像管道和消息队列等通信方式,则需要在内核和用户空间进行四次的数据拷贝,