进程间通信(三)-----共享内存

共享内存:使得多个进程可以访问同⼀一块内存空间,是最快的可⽤用IPC形式。是针对其他通信机制运⾏行效率较低⽽而设计的。往往与其它通信机制,如信号量结合使⽤用,来达到进程间的同步及互斥

共享内存应开辟到地址空间堆栈之间的区域,即0-3G的用户区

生命周期:随内核

comm.h

#ifndef _COMM_H_
#define _COMM_H_
#define PATHNAME "."
#define PROJ_ID 0x666
#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<sys/ipc.h>
#include<sys/shm.h>
int create_shm(int size);
int comm_shm(int size,int flags);
int get_shm();
int destroy_shm(int shmid);
void *at_shm(int shmid);
int dt_shm(const void *shmadd);
#endif
comm.c

#include"comm.h"
int comm_shm(int size,int flags)
{
  key_t key=ftok(PATHNAME,PROJ_ID);
  if(key<0)
  {
    perror("ftok");
	return -1;
  }
  int shmid=shmget(key,size,flags);
  if(shmid<0)
  {
    perror("ftok");
	return -2;
  }
  return shmid;
}
int create_shm(int size)
{
  return comm_shm(size,IPC_CREAT | IPC_EXCL | 0666);
}
int get_shm()
{
  return comm_shm(0,IPC_CREAT);
}
int destroy_shm(int shmid)
{
if(shmctl(shmid,IPC_RMID,NULL)<0)
{
  perror("shmctl");
  return -1;
}
return 0;
}
void *at_shm(int shmid)
{
  return shmat(shmid,NULL,0);
}
int dt_shm(const void *shmadd)
{
  return shmdt(shmadd);
}

client.c

#include"comm.h"
int main()
{
 int shmid=get_shm();
 char* buf=(char*)at_shm(shmid);
 while(1)
 {
   printf("%s\n",buf);
   sleep(3);
 }
 dt_shm(buf);
 destroy_shm(shmid);
}

sever.c

#include"comm.h"
int main()
{
  int shmid=create_shm(4096);
  if(shmid<0)
  {
    perror("get_shm");
	return -1;
  }
  char* buf=(char*)at_shm(shmid);
  int count=0;
  while(count<4096)
  {
   buf[count]='A'+count%26;
   ++count;
   sleep(3);
   buf[count]=0;
   }
  dt_shm(buf);
  return 0;
}
Makefile

.PHONY:all
all:client sever
client:comm.c client.c
	gcc -o $@ $^
sever:comm.c sever.c
	gcc -o $@ $^
.PHONY:clean
clean:
	rm -f sever client

运行结果




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值