共享存储
来源:互联网 发布:hanoi塔递归算法c语言 编辑:程序博客网 时间:2024/04/28 20:29
两个进程之间通过共享存储传递结构体数据,进程之间通过信号量来同步操作
shmsev.c
#include <sys/shm.h>#include <sys/ipc.h>#include <sys/sem.h>#include <stdio.h>#include <stdlib.h>#include <stdlib.h>#include <string.h>#include <unistd.h>#include <errno.h>#define SHM_SIZE 1024union semum{int val;struct semid_ds *buf;unsigned short *array;};typedef struct{int age;char name[10];}people;int main(){key_t key;int shmid,semid;union semum sem_val;struct sembuf sem_buf;char buf[1024];char temp[10];people *p;int i=0;key = ftok("/root/one", 2013);shmid = shmget(key, SHM_SIZE, IPC_CREAT|0666);semid = semget(key, 1, IPC_CREAT|0666);printf("key = %d\n", key);printf("shmid = %d\n", shmid);printf("semid = %d\n", semid);sem_val.val = 1;semctl(semid, 0, SETVAL, sem_val);p = (people *)shmat(shmid, 0, 0);//P()sem_buf.sem_num = 0;sem_buf.sem_op = -1;sem_buf.sem_flg = SEM_UNDO;semop(semid, &sem_buf, 1);memset(temp, 0x00, sizeof(temp));strcpy(temp, "wang");temp[4] = '0';for(i=0; i<3; i++){temp[4]+=1;strncpy((p+i)->name, temp, 5);(p+i)->age=20+i;}//strcpy(buf, "Can you hear me? I am servers!\n");//memcpy(shm_addr, buf, strlen(buf));//V()sem_buf.sem_op = 1;semop(semid, &sem_buf, 1);shmdt(p);return 0;}
shmcli.c
#include <stdio.h>#include <stdlib.h>#include <string.h>#include <errno.h>#include <sys/sem.h>#include <sys/ipc.h>#include <sys/shm.h>#define SHM_SIZE 1024typedef struct{int age;char name[10];}people;int main(){key_t key;int shmid, semid;struct sembuf sem_buf;people *p;int i=0;key = ftok("/root/one", 2013);shmid = shmget(key, 0, 0666);semid = semget(key, 1, 0666);printf("key = %d\n", key);printf("shmid = %d\n", shmid);printf("semid = %d\n", semid);p = (people *)shmat(shmid, 0, 0);//P()sem_buf.sem_num = 0;sem_buf.sem_op = -1;sem_buf.sem_flg = SEM_UNDO;semop(semid, &sem_buf, 1);for(i=0; i<3; i++){printf("name:%s\n",(*(p+i)).name);printf("age %d\n", (*(p+i)).age);}//printf("cli recved==>: %s \n", shm_addr);//V()sem_buf.sem_op = 1;semop(semid, &sem_buf, 1);shmdt(p);//semctl(semid, 0, IPC_RMID, 0);//shmctl(shmid, IPC_RMID, NULL);return 0;}
[root@localhost one]# ./shmsev
key = -586474867
shmid = 1245204
semid = 524291
[root@localhost one]# ./shmcli
key = -586474867
shmid = 1245204
semid = 524291
name:wang1
age 20
name:wang2
age 21
name:wang3
age 22
- 共享存储
- 共享存储
- SNIA 共享存储模型
- 存储共享文件系统需求
- APUE_共享存储区
- 【创建共享存储--虚拟机】
- OCM_Session7_7_VBOX配置共享存储
- ISCSI共享存储模拟
- vmware 配置共享存储
- 共享存储技术
- 共享存储函数
- 共享存储NFS
- 六、Linux--共享存储
- NFS共享存储
- Iscsi实现共享存储
- NFS共享存储
- samba共享存储服务
- Linux搭建共享存储,Window访问共享存储
- C#实现窗体截图(代码+效果)
- android Fragment
- jQuery选择器
- Flex中设置TextArea的行家
- ECMALL会员等级,自定义等级类型,自定义等级价格
- 共享存储
- C++内存分区
- 猿题库iOS客户端的技术细节(三):基于CoreText的排版引擎
- 各个数据库的取一表前N条记录不同SQL写法
- QT的Graphics View柜架(1/3)
- 虚拟专用网(VPN)技术原理
- IOS: RoadMapIOS 应用程序开发过程
- Daikon Forge 学习笔记(一)之 面板的制作
- 恐惧的原因