当前位置:  技术问答>linux和unix

进程间怎样共享内存?

    来源: 互联网  发布时间:2015-04-15

    本文导语:  我在linux建立一个程序服务器,为了提高效率,我想采用多进程,一个进程用于接收别的程序传输来的数据,另外一个进程用来读取这些数据.这样两个进程通过共享内存实现通讯.哪位能给我一个这样的例子,既建立了两个进...

我在linux建立一个程序服务器,为了提高效率,我想采用多进程,一个进程用于接收别的程序传输来的数据,另外一个进程用来读取这些数据.这样两个进程通过共享内存实现通讯.哪位能给我一个这样的例子,既建立了两个进程,两个进程间又是通过共享内存实现通讯的.我的邮箱是:breaveheart@tom.com.
先谢谢了!(如果有window环境下,一起发给我就更好了!)

|
你为什么要用多进程呢?用多线程不行吗?多个线程共享同一个地址空间,只要进行一些必要的同步处理应该就能搞定。

|
//给你一个例子,分配20M共享内存。
//主线程往内存中写数据,thread_proc从共享内存中毒数据

#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 


#define SHM_SIZE (20 * 1024 * 1024) // 20M

static key_t SHM_KEY = 12345;

static int shm_id = -1;
static int running = 1;

void * thread_proc(void *p)
{
char *buf;
int shmid = shmget(SHM_KEY, SHM_SIZE, 0666);
if (shm_id == -1)
{
perror("get share memory");
return NULL;
}

buf = (char *)shmat(shmid, NULL, 0);

while(running)
{
sleep(1);
printf("%sn", buf);
}
return 0;
}

void exit_do()
{
if (shm_id != -1)
{
if (shmctl(shm_id, IPC_RMID, 0) == -1)
{
perror("delete share memory");
}
}
}

void sig_do(int sig)
{
running = 0;
exit(0);
}

int main()
{
pthread_t pid;
char *buf;
int i = 0;

atexit(exit_do);
signal(SIGINT, sig_do);

shm_id = shmget(SHM_KEY, SHM_SIZE, IPC_CREAT|0666);
if (shm_id == -1)
{
perror("create share memory");
return -1;
}

buf = shmat(shm_id, NULL, 0);

pthread_create(&pid, NULL, thread_proc, NULL);
while(1)
{
sprintf(buf, "This is a test! times: %d", i++);
sleep(1);
}
return 0;
}


|
http://joyfire.net/jln/system/11.html

希望对你有用

|
shmget,shmat.

    
 
 

您可能感兴趣的文章:

  • Ubuntu查看内存,进程相关命令介绍
  • 程序在fork前申请了内存若干,在fork后子进程是否需要释放父进程之前申请的内存
  • linux下进程占用内存空间详解
  • 主进程有两个线程,fork子进程后复制主进程两个线程的内存么?
  • linux下进程间通信:共享内存原理及具体用法举例(基于c/c++语言)
  • 多个进程对系统V共享内存进行读写,怎样实现对共享内存部分进行加解锁?
  • 怎么打开一个进程并得到这个进程内存使用的信息?
  • 关于大于2G内存的使用.....按32位编译的进程怎么使用大于2G的内存?
  • 我执行top命令,显示出来所有进程占内存都不超过1%,可是512M内存只剩30多M,为什么?
  • 通过c程序写代码怎么查看进程是不是存在了?怎么查看该进程占用的内存是多少?
  • linux中用killall命令杀死进程的时候会释放掉该进程所占有的内存吗?
  • 在linux,如何用共享内存来实现进程间的通讯?(这些进程没有父子关系)
  • linux进程(线程)运行过程中如何获取本进程当前的内存使用状况,统计信息?
  • 求救:AIX下java进程堆内存存在大量空余,但rss内存不断增加
  • 用top命令查看一个进程,虚拟内存一直不变,但物理内存每时5s增长12k或20k.
  • 大家好,我想问下有人用过"linux进程的内存使用解析"中推荐使用的"Ben Maurer写的perl脚本"查看内存么
  • 进程内存泄漏的问题
  • 请教:linux下如何检测并控制进程的内存大小?
  • 进程间共享内存问题。
  • linux如何限制指定进程的内存使用量?
  • Linux0.11进程最大可用虚拟内存为64M?
  • 如何在父进程和子进程共享一个变量??
  • 多进程共享变量
  • linux内核高手进!关于调用__fork()时0号进程的子进程才能与父进程共享PID的困惑
  • 父子进程共享数据的问题
  • 编程模拟多进程共享临界资源
  • 进程与线程资源的共享问题
  • linux:这样能实现父、子进程共享变量吗?
  • 进程同时访问两个大共享内存,会失败?
  • 服务器端的共享内存可否被远程客户端的进程所挂载使用?
  • 多进程编程中,可否共享数据对象?
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • linux僵尸(zombie)进程介绍及清除
  • 进程Afork进程B,进程Bfor进程C,如果进程C退出发出SIGCHLD,A进程是否可以收到
  • Linux进程的内核栈和用户栈概念,相互关系及切换过程
  • 如果一个server进程要fork许多子进程,但不等待子进程终止,也不希望子进程结束后处于僵进程状态直到父进程终止。请问可采用什么方法实现
  • android 4.0 托管进程介绍及优先级和回收机制
  • WEB前端 iis7站长之家
  • fock()开出的子进程的进程ID是否进程ID都大于父进程的?
  • 父进程等待子进程n秒,如果子进程正常退出,父进程立即继续向下执行,如果子出现进程故障一直不退出,父进程等待n秒后继续向下执行,请问
  • 多进程问题 子进程读取内容 读完挂起,父进程写 写入后唤醒子进程
  • 一个进程首先监听一个端口,等到有连接了就新开一个进程,让新进程来处理后面的通讯。请问母进程中已经打开了端口,子进程怎么来使用同一
  • 我在一个父进程中,生成了4个子进程,子进程的优先级是一样的。我现在想结束子进程。该如何做?
  • 子进程wait/waitpid//子进程不结束,父进程会等待子进程吗?
  • 在一个进程中我定义了几个全局变量,然后我又fork了几个子进程,子进程中是否可以各自对全局变量进行修改,如果各子进程都对其进行修改,
  • 怎样一次杀掉父进程创建的所有子进程?我在父进程中用kill(0,SIGKILL),结果父进程也给干掉了,参数0难道不是表示除自己外的所有同uid的进
  • 进程创建进程组后,然后创建该组中的进程,然后终止。这里的终止....?
  • 如何实现子进程根据父进程的信号来确定是否终止子进程???
  • 高手请教!linux怎样通过pid获取进程信息,如:进程名、进程状态等?
  • 如何通过进程号获得进程的一些信息,例如:进程运行的目录
  • 【如何彻底杀死子进程】Kill -9子进程后进程呈僵死状态
  • 信号灯同步2个进程,一个进程如何主动给另一个进程发送通知?
  • fork 一个字进程 将子进程的输出作为主进程的输入


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3