代码:

 #include <stdio.h>
#include <stdlib.h>
#include <sys/shm.h>
/*************基本的函数API********************
共享内存函数API
int shmget(key_t key, int size, int flag)
key:
共享内存的键值,多个进程可以通过它访问同一个共享内存。常用特殊值:IPC_PRIVATE,创建当前进程的私有共享内存
size:
指定创建共享内存的大小
flag:
操作权限
char * shmat(int shm_id, const void * addr, int flag)
shm_id:
要映射的共享内存标识符
addr:
指定在调用进程中映射共享内存的地址。通常取值为0,表示由系统自动分配地址。
flag:
设置共享内存的操作权限。若取值为0,表示可对共享内存进行读写操作。
int shmctl(int shm_id, int cmd, struct shmid_ds * buf)
shm_id:
共享内存标识符
cmd:
指定索要进行的操作:IPC_STAT IPC_SET IPC_RMID SHM_LOCK SHM_UNLOCK
buf:
结构体型指针
int shmdt(const void * addr)
**********************************************/
#define Test_pipe 0
#define Test_Shmget 0
#define Test_AT_w 0
#define Test_AT_r 0
#define Test_DT 1
int main(int argc, char *argv[])
{
#if Test_pipe
int x,fd[];
char buf[],s[];
pipe(fd);
x = fork();
if( == x)
{
sprintf(buf,"This is an pipe!");
write(fd[],buf,);
exit();
}
else
{
wait();
read(fd[],s,);
printf("read: %s\n",s);
}
#endif #if Test_Shmget
int shm_id;
shm_id = shmget(IPC_PRIVATE,,);
if(shm_id < )
{
perror("shmget id < 0");
exit();
}
printf("成功建立共享内存区域: %d\n",shm_id);
system("ipcs -m");
#endif #if Test_AT_w
int shm_id;
char *shm_buf;
shm_id = atoi(argv[]);
shm_buf = shmat(shm_id,,);
printf("写如数据到共享内存:\n");
sprintf(shm_buf,"对共享内存的读写操作!");
printf("%s\n",shm_buf);
#endif #if Test_AT_r
int shm_id;
char *shm_buf,str;
shm_id = atoi(argv[]);
shm_buf = shmat(shm_id,,);
printf("写如数据到共享内存:\n");
sprintf(str,shm_buf);
printf("%s\n",str);
system("ipcs -m");
#endif #if Test_DT
int shm_id;
char *shm_buf;
shm_id = atoi(argv[]);
shm_buf = shmat(shm_id,,);
shmdt(shm_buf);
shmctl(shm_id,IPC_RMID,NULL);
system("ipcs -m");
#endif
}

IPC通讯中共享内存参看代码:

Client端代码client.c(gcc client.c -lm -o client

shmget函数得到的共享内存的大小有参数确定,参数的单位是Byte!

同样的shmget参数的0666代表的内容是,共享内存空间的可读可写性!

使用ftok函数获取的key_t key的作用在于生成一个文件节点引索,这样才能够连接两个进程让他们以这个引索值作为标识ID!

shmdt函数用来删除释放掉创建的共享内存空间!

shmat函数用来映射已经创建好的虚拟内存空间地址!返回值为两个进程进行操作的共享内存起始地址!

#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/shm.h>
#include <time.h>
#include <math.h> #define random(x) (rand()%x)
#define PI 3.1415926 #define Width 20
#define Height 20 int main(int argc,char *argv[])
{
key_t key = ;
int shmid = ;
setbuf(stdout,NULL);
printf("Begin to Create the shared-mem...\n");
key = ftok(".",); // Get the only IPC ID:inode'num + 1
if(key<)
{
perror("ftok");
return -;
}
printf("key=%d\n",key);
sleep();
printf("...\n");
printf("%d\n",IPC_CREAT);
shmid = shmget(key,,IPC_EXCL | IPC_CREAT | ); // Get shared mem:IPC_ID_key Mem_size
if(shmid<)
{
perror("shmget");
return -;
}
char * shared_mem_addr = shmat(shmid,NULL,); // mapping the mem_addr to the addr of the Process
printf("...\n"); sleep(); // waitting for setup the mem printf("The shared-mem create sucessfully!\n");
printf("Begin to insert the data into shared-mem!\n");
int i=;
while(i<Width*Height)
{
*(shared_mem_addr+i) = *sin((double)i*PI/180.0);// random(255)+255;
usleep();
printf(".");
i++;
}
printf("\nThe data insert finish!\n");
shmdt(shared_mem_addr);
return ;
}

Server端代码server.c(gcc server.c -o server

#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/shm.h>
#include <time.h> #define Width 20
#define Height 20 int main(int argc,char *argv[])
{
key_t key = ;
int shmid = ;
key = ftok(".",); // Get the only IPC ID:inode'num + 1
if(key<)
{
perror("ftok");
return -;
}
shmid = shmget(key,,IPC_CREAT | ); // Get shared mem:IPC_ID_key Mem_size
if(shmid<)
{
perror("shmget");
return -;
}
char * shared_mem_addr = shmat(shmid,NULL,); // mapping the mem_addr to the addr of the Process sleep(); int i=;
while(i<Width*Height)
{
printf("The image data:%d\n",*(shared_mem_addr+i));
usleep();
i++;
}
shmdt(shared_mem_addr);
sleep();
shmctl(shmid,IPC_RMID,NULL);
return ;
}

首先运行Clent端,然后再运行Server端即可!

参看IPC通讯介绍:https://www.cnblogs.com/CheeseZH/p/5264465.html

Linux下C语言进程通讯编程的更多相关文章

  1. linux下C语言socket网络编程简例

    原创文章,转载请注明转载字样和出处,谢谢! 这里给出在linux下的简单socket网络编程的实例,使用tcp协议进行通信,服务端进行监听,在收到client的连接后,发送数据给client:clie ...

  2. linux下c语言的多线程编程

    我们在写linux的服务的时候,经常会用到linux的多线程技术以提高程序性能 多线程的一些小知识: 一个应用程序可以启动若干个线程. 线程(Lightweight Process,LWP),是程序执 ...

  3. linux下C语言多线程编程实例

    用一个实例.来学习linux下C语言多线程编程实例. 代码目的:通过创建两个线程来实现对一个数的递加.代码: //包含的头文件 #include <pthread.h> #include ...

  4. Linux下C语言编程实现spwd函数

    Linux下C语言编程实现spwd函数 介绍 spwd函数 功能:显示当前目录路径 实现:通过编译执行该代码,可在终端中输出当前路径 代码实现 代码链接 代码托管链接:spwd.c 所需结构体.函数. ...

  5. Linux基础与Linux下C语言编程基础

    Linux基础 1 Linux命令 如果使用GUI,Linux和Windows没有什么区别.Linux学习应用的一个特点是通过命令行进行使用. 登录Linux后,我们就可以在#或$符后面去输入命令,有 ...

  6. LINUX下C语言编程基础

    实验二 Linux下C语言编程基础 一.实验目的 1. 熟悉Linux系统下的开发环境 2. 熟悉vi的基本操作 3. 熟悉gcc编译器的基本原理 4. 熟练使用gcc编译器的常用选项 5 .熟练使用 ...

  7. LINUX下C语言编程调用函数、链接头文件以及库文件

    LINUX下C语言编程经常需要链接其他函数,而其他函数一般都放在另外.c文件中,或者打包放在一个库文件里面,我需要在main函数中调用这些函数,主要有如下几种方法: 1.当需要调用函数的个数比较少时, ...

  8. Linux下C语言编程基础学习记录

    VIM的基本使用  LINUX下C语言编程 用gcc命令编译运行C语言文件 预处理阶段:将*.c文件转化为*.i预处理过的C程序. 编译阶段:将*.i文件编译为汇编代码*.s文件. 汇编阶段:将*.s ...

  9. 【转】Linux基础与Linux下C语言编程基础

    原文:https://www.cnblogs.com/huyufeng/p/4841232.html ------------------------------------------------- ...

随机推荐

  1. 23)django-缓存

    一:目录 1)简介 2)django缓存方式 3)django应用方式 二:简介 由于Django是动态网站,所有每次请求均会去数据进行相应的操作,当程序访问量大时,耗时必然会更加明显, 最简单解决方 ...

  2. Url解码和编码 escape()、encodeURI()、encodeURIComponent()区别详解

    Server.UrlDecode;解码 Server.UrlEncode;编码 url编码是一种浏览器用来打包表单输入的格式.浏览器从表单中获取所有的name和其中的值 ,将它们以name/value ...

  3. setenforce: SELinux is disabled解决办法

    如果在使用setenforce命令设置selinux状态的时候出现这个提示:setenforce: SELinux is disabled 那么说明selinux已经被彻底的关闭了 如果需要重新开启s ...

  4. Confluence 6 为搜索引擎隐藏外部链接

    为搜索引擎隐藏外部链接能够避免向你的站点添加垃圾信息.如果你启用了这个选项的话,任何插入到页面中的 URLs 和评论将会赋予 'nofollow' 属性,这个属性将会禁止搜索引擎进行索引.  快捷链接 ...

  5. 设置外部查找工具来索引 Confluence 6

    任何网页的 crawler  工具都可以被用来索引你的 Confluence 站点中的内容.如果你希望注册用户才能够查看的内容也被索引的话,你需要为你的 Confluence 创建一个只被 crawl ...

  6. 【Linux】系统基本命令

    # lsb_release -a 查看系统版本# uname -a # 查看内核/操作系统/CPU信息 # head -n 1 /etc/issue # 查看操作系统版本 # cat /proc/cp ...

  7. vue之$forceUpdate

    由于一些嵌套特别深的数据,导致数据更新了.UI没有更新(连深度监听都没有监听到) this.$forceUpdate();

  8. java----DOS命令

    dir /?   查看帮助 dir /s   查看当前的目录,以及子目录

  9. hdu4370 dijkstra矩阵转单向边最短路矩阵+自环闭环

    /* 矩阵太神奇了Orz,网上的题解大多是spfa,不过我发想dijkstra也能做 把n*n的矩阵看成是单向边距离矩阵就行 */ #include<iostream> #include& ...

  10. AI学习吧-REDIS-常识

    Redis 是一个non-sql,非关系型数据库,数据存放在内存中,支持持久化,redis中的数据会在一段时间内和(mysql等数据库)磁盘进行同步,防止丢失,这样也就降低了读数据效率. Redis和 ...