POSIX共享内存函数介绍

shm_open

功能:
用来创建或打开一个共享内存对象
原型:
int shm_open(const char *name, int oflag, mode_t mode);
参数:
name : 共享内存对象的名字(命名规则和POSIX消息队列一样)
oflag :与open函数类似,可以是O_RDONLY、O_WRONLY、O_RDWR,还可以按位或上O_CREAT、O_EXCL、O_TRUNC等
mode : 此参数总是需要设置,如果oflag没有指定O_CREAT,可以指定为0 返回值:
成功 : 成功返回非负整数文件描述符
失败 : -1

ftruncate

功能:
修改共享内存的大小(还可以用来修改文件的大小)
原型:
int ftruncate(int fd, off_t length);
参数:
fd : 文件描述符
length :长度 返回值:
成功 : 0
失败 : -1

fstat

功能:
获取共享内存对象信息(还可以用来获取文件的信息)
原型:
int fstat(int fd, struct stat *buf);
参数:
fd : 文件描述符
buf :返回共享内存状态 返回值:
成功 : 0
失败 : -1

shm_unlink

功能:
删除共享内存对象
原型:
int shm_unlink(const char *name);
参数:
name : 共享内存对象的名字 返回值:
成功 : 0
失败 : -1

mmap

功能:
将共享内存对象映射到进程地址空间
原型:
void *mmap(void *addr, size_t length, int prot, int flags, int fd, off_t offset);
参数:
addr : 要映射的起始地址,通常指定为NULL,让内核自动选择
length : 映射到进程地址空间的字节数
prot : 映射区保护方式
flags : 标志
fd : 文件描述符
offset : 从文件头开始的偏移量 返回值:
成功 : 成功返回映射到的内存的起始地址
失败 : -1

POSIX共享内存示例

  共享内存已经自动挂载到/dev/shm目录下

shm_open.c

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/mman.h>
#include <sys/stat.h> /* For mode constants */
#include <fcntl.h> /* For O_* constants */
#include <sys/types.h> #define ERR_EXIT(m) \
do \
{ \
perror(m); \
exit(EXIT_FAILURE); \
} while (0) typedef struct stu{
char name[32];
int age;
}STU; int main(int argc, char const *argv[])
{ int shmid;
//创建一个共享内存
//创建的时候指定的权限是0666,创建后不一定是666,它还取决于umask,公式 mode & ~umask
shmid = shm_open("/xyz", O_CREAT|O_RDWR, 0666);
if(shmid == -1)
ERR_EXIT("shm_open"); printf("shm_open success\n"); //改变共享内存的大小
if(ftruncate(shmid,sizeof(STU)) == -1)
ERR_EXIT("ftruncate"); //获取共享内存的信息
struct stat buf;
if(fstat(shmid, &buf) == -1)
ERR_EXIT("fstat"); printf("size : %ld mode : %o\n",buf.st_size, buf.st_mode & 0777); close(shmid);
return 0;
}

shm_write.c

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <sys/mman.h>
#include <sys/stat.h> /* For mode constants */
#include <fcntl.h> /* For O_* constants */
#include <sys/types.h> #define ERR_EXIT(m) \
do \
{ \
perror(m); \
exit(EXIT_FAILURE); \
} while (0) typedef struct stu{
char name[32];
int age;
}STU; int main(int argc, char const *argv[])
{ int shmid;
//创建一个共享内存 shmid = shm_open("/xyz", O_RDWR, 0);
if(shmid == -1)
ERR_EXIT("shm_open"); printf("shm_open success\n"); //获取共享内存的信息
struct stat buf;
if(fstat(shmid, &buf) == -1)
ERR_EXIT("fstat"); STU *p;
//如果指定了PROT_WRITE和MAP_SHARED,shm_open的oflag应该指定为O_RDWR,否则会出现mmap: Permission denied
p = mmap(NULL, buf.st_size, PROT_WRITE, MAP_SHARED, shmid, 0);
if(p == MAP_FAILED)
ERR_EXIT("mmap"); strcpy(p->name, "test");
p->age = 20; close(shmid);
return 0;
}

shm_read.c

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <sys/mman.h>
#include <sys/stat.h> /* For mode constants */
#include <fcntl.h> /* For O_* constants */
#include <sys/types.h> #define ERR_EXIT(m) \
do \
{ \
perror(m); \
exit(EXIT_FAILURE); \
} while (0) typedef struct stu{
char name[32];
int age;
}STU; int main(int argc, char const *argv[])
{ int shmid;
//创建一个共享内存 shmid = shm_open("/xyz", O_RDONLY, 0);
if(shmid == -1)
ERR_EXIT("shm_open"); printf("shm_open success\n"); //获取共享内存的信息
struct stat buf;
if(fstat(shmid, &buf) == -1)
ERR_EXIT("fstat"); STU *p;
//如果指定了PROT_WRITE和MAP_SHARED,shm_open的oflag应该指定为O_RDWR,否则会出现mmap: Permission denied
p = mmap(NULL, buf.st_size, PROT_READ, MAP_SHARED, shmid, 0);
if(p == MAP_FAILED)
ERR_EXIT("mmap"); printf("name : %s\n", p->name);
printf("age : %d\n", p->age); close(shmid);
return 0;
}

shm_unlink.c

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/mman.h>
#include <sys/stat.h> /* For mode constants */
#include <fcntl.h> /* For O_* constants */ #define ERR_EXIT(m) \
do \
{ \
perror(m); \
exit(EXIT_FAILURE); \
} while (0) int main(int argc, char const *argv[])
{ shm_unlink("/xyz");
return 0;
}

第三十五章 POSIX共享内存的更多相关文章

  1. Gradle 1.12用户指南翻译——第三十五章. Sonar 插件

    本文由CSDN博客万一博主翻译,其他章节的翻译请参见: http://blog.csdn.net/column/details/gradle-translation.html 翻译项目请关注Githu ...

  2. “全栈2019”Java多线程第三十五章:如何获取线程被等待的时间?

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java多 ...

  3. “全栈2019”Java第三十五章:面向对象

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...

  4. 第三十九章 POSIX信号量与互斥锁

    POSIX信号量相关函数 sem_open 功能: initialize and open a named semaphore 原型: sem_t *sem_open(const char *name ...

  5. 【WPF学习】第三十五章 资源字典

    如果希望在多个项目之间共享资源,可创建资源字典.资源字典只是XAML文档,除了存储希望使用的资源外,不做其他任何事情. 一.创建资源字典 下面是一个资源字典示例,它包含一个资源: <Resour ...

  6. 第三十五章 metrics(3)- codahale-metrics基本使用

    <!-- metrics --> <dependency> <groupId>io.dropwizard.metrics</groupId> <a ...

  7. 【第三十五章】 metrics(3)- codahale-metrics基本使用

    <!-- metrics --> <dependency> <groupId>io.dropwizard.metrics</groupId> <a ...

  8. SpringBoot | 第三十五章:Mybatis的集成和使用

    前言 最近收到公众号留言说,单纯的Mybatis的集成和使用.前面在第九章:Mybatis-plus的集成和使用介绍了基于mybatis-plus的集成和使用.后者也只是对mybatis进行了功能增强 ...

  9. 第三十五章 Linux常规练习题(二)参考答案

    一.练习题一 1.删除用户基本组shanghai03.发现无法正常删除,怎样才能将其删除掉,不能删除用户. groupdel shanghai03 移除其所属组的用户 2.打开多个xshell窗口连接 ...

随机推荐

  1. ELK系列(二):.net core中使用ELK

    ELK安装好后,我们现在.net Core中使用一下,大体思路就是结合NLog日志组件将数据写入ELK中,其它语言同理. ELK的安装还是有些复杂的,我们也可以在Docker中安装ELK:docker ...

  2. malformed header from script. Bad header的解决方法

    今天配了CGI服务器,打开CGI报错: [Wed Jun 02 13:57:21 2010] [error] [client 192.168.0.1] malformed header from sc ...

  3. 快学Scala 第十三课 (类型层级,对象相等性)

    Scala 类型层级: 对象相等性: 和Java一样要重写equals方法和hashcode方法 class Student(val id: Int, val name: String) { over ...

  4. 最近学到的Git知识,大厂的Git机制还是很方便的

    本文首发于微信公众号:程序员乔戈里 转载请注明:https://blog.csdn.net/WantFlyDaCheng/article/details/102538508 一.两次的 git com ...

  5. springmvc框架的使用

    1.在idea中新建java web项目,引入spring和springmvc所需jar包,其中 spring-web-3.2.12.RELEASE.jar:在web应用开发时使用spring框架所需 ...

  6. http post 请求,带参数,带请求头

    #!/usr/bin/env python # -*- coding: utf-8 -*- import requests import json url = 'http://............ ...

  7. Spring bean的作用域以及生命周期

    一.request与session的区别 request简介 request范围较小一些,只是一个请求. request对象的生命周期是针对一个客户端(说确切点就是一个浏览器应用程序)的一次请求,当请 ...

  8. JVM之内存结构详解

    对于开发人员来说,如果不了解Java的JVM,那真的是很难写得一手好代码,很难查得一手好bug.同时,JVM也是面试环节的中重灾区.今天开始,<JVM详解>系列开启,带大家深入了解JVM相 ...

  9. mysqlbinlog增量恢复(基于使用事件位置position的恢复)

    1.在xtrabackup 备份+还原文章中我们记录了备份到的binlog文件名和position点位置使用如下命令就可以进行增量的恢复了shell> mysqlbinlog --stop-po ...

  10. Python:的web爬虫实现及原理(BeautifulSoup工具)

    最近一直在学习python,学习完了基本语法就练习了一个爬虫demo,下面总结下. 主要逻辑是 1)初始化url管理器,也就是将rooturl加入到url管理器中 2)在url管理器中得到新的new_ ...