http://download1.youkuaiyun.com/down3/20070529/29183222619.Chttp://download1.youkuaiyun.com/down3/20070529/29183246962.Chttp://download1.youkuaiyun.com/down3/20070529/29183246962.Chttp://download1.youkuaiyun.com/down3/20070529/29183246962.C
源代码是从别人的文章中抄过来的,不是原创,不过写得不错,主要是描述两个不同的进程从共享内存中存取数据的技术,我加了点分析:
第一个是写数据:
/***** testwrite.c *******/
#include <sys/ipc.h>
#include <sys/shm.h>
#include <sys/types.h>
#include <unistd.h>
typedef struct{
char name[4];
int age;
} people;
main(int argc, char** argv)
{
int shm_id,i;
key_t key;
char temp;
people *p_map;
char* name = "/dev/shm/myshm2";
key = ftok(name,0);
if(key==-1)
perror("ftok error");
/*先用ftokR建一个key,再
圏 pshmget , R 建一 WW 共享内存区域 */
shm_id=shmget(key,4096,IPC_CREAT);
if(shm_id==-1)
{
perror("shmget error");
return;
}
/* 将ル集 W 共享内存区附加到自己的内存段 */
p_map=(people*)shmat(shm_id,NULL,0);
temp='a';
for(i = 0;i<10;i++)
{
temp+=1;
memcpy((*(p_map+i)).name,&temp,1);
(*(p_map+i)).age=20+i;
}
/* 写数据完ユ k ,将其从自己的内存段中 “ R 除 ” 出去 */
if(shmdt(p_map)==-1)
perror(" detach error ");
}
/* 读进 程首先要得到那 块 内存 块 , 这 个 时 候, ftok 根据文件名和 ID 创 建的 key 就
很用了,步 骤 同 创 建是一 样 的 */
/********** testread.c ************/
#include <sys/ipc.h>
#include <sys/shm.h>
#include <sys/types.h>
#include <unistd.h>
typedef struct{
char name[4];
int age;
} people;
main(int argc, char** argv)
{
int shm_id,i;
key_t key;
people *p_map;
char* name = "/dev/shm/myshm2";
key = ftok(name,0);
if(key == -1)
perror("ftok error");
shm_id = shmget(key,4096,IPC_CREAT);
if(shm_id == -1)
{
perror("shmget error");
return;
}
p_map = (people*)shmat(shm_id,NULL,0);
for(i = 0;i<10;i++)
{
printf( "name:%s/n",(*(p_map+i)).name );
printf( "age %d/n",(*(p_map+i)).age );
}
if(shmdt(p_map) == -1)
perror(" detach error ");
}
gcc -o testWriter -g testWriter.C
gcc -o testRead -g testRead.C
ipcs 察看 创 建的共享内存
注:事 实 上, ftok 函数 仅仅 是根据文件名和 ID 生成一个起 标识 作用的 key ,根据《 GNU Linux 编 程指南》 说 , Linux 下 实现这 一函数 还 有点 问题 ,不推荐用。于是我一般来 说 都是自己定 义 一个唯一的 key ,而不使用 ftok 函数。