- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我知道这可能是一个愚蠢的问题,但我一直在寻找一段时间,无法找到明确的答案。如果我使用 mmap
或 malloc
(在 C 语言中,在 linux 机器上)是否会在 RAM 中分配空间?例如,如果我有 2GB 的 RAM 并且想要使用所有可用的 RAM,我可以只使用 malloc/memset
组合、mmap
,还是有其他我不使用的选项?不知道吗?
我想编写一系列可以同时运行的简单程序,并保留进程中使用的所有 RAM 以强制使用交换,并频繁换入/换出页面。我已经用下面的程序试过了,但这并不是我想要的。它确实分配了内存(RAM?),并强制使用交换(如果有足够的实例正在运行),但是当我调用 sleep
时,这并不仅仅是锁定内存不被使用(所以没有什么是实际上是从其他进程中换入或换出的?),还是我误解了什么。
例如,如果我运行 3 次,我将使用前两个实例的 2GB(全部)RAM,然后第三个实例将前两个实例中的一个交换出(RAM)和当前实例进入内存?还是实例 #3 只使用磁盘或虚拟内存运行?
这又带来了一点,我是否需要分配足够的内存来使用所有可用的虚拟内存以及要使用的交换分区?
最后,mmap
(或任何其他 C 函数。见鬼,如果适用的话,甚至是另一种语言)会更好吗?
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MB(size) ( (size) * 1024 * 1024)
#define GB(size) ( (size) * 1024 * 1024 * 1024)
int main(){
char *p;
p = (char *)malloc(MB(512));
memset(p, 'T', MB(512));
printf(".5 GB allocated...\n");
char *q;
q = (char *)malloc(MB(512));
memset(q, 'T', MB(512));
printf("1 GB allocated...\n");
printf("Sleeping...\n");
sleep(300);
}
** 编辑:我正在为我的操作系统使用 CentOS 6.4(带有 3.6.0 内核),如果有帮助的话。
最佳答案
这非常依赖于操作系统/机器。
在大多数操作系统中,它们都不分配 RAM。它们都分配 VM 空间。它们使一定范围的进程虚拟内存可供使用。 RAM 通常在第一次写入时由操作系统稍后分配。在那之前,这些分配不使用 RAM(除了将它们列为有效 VM 空间的页表)。
如果要分配物理 RAM,则必须使每个页面(sysconf(_SC_PAGESIZE)
为您提供系统页面大小)变脏。
在 Linux 中,您可以在 /proc/self/smaps
中查看包含所有详细信息的 VM 映射。 Rss
是该映射的常驻集(有多少驻留在 RAM 中),其他所有脏的都将被换出。所有非脏内存都可以使用,但在那之前不会存在。
你可以用类似的东西弄脏所有页面
size_t mem_length;
char (*my_memory)[sysconf(_SC_PAGESIZE)] = mmap(
NULL
, mem_length
, PROT_READ | PROT_WRITE
, MAP_PRIVATE | MAP_ANONYMOUS
, -1
, 0
);
int i;
for (i = 0; i * sizeof(*my_memory) < mem_length; i++) {
my_memory[i][0] = 1;
}
在某些实现中,这也可以通过将 MAP_POPULATE
标志传递给 mmap
来实现,但是(取决于您的系统)它可能会失败 mmap
和 ENOMEM
如果你尝试映射更多,那么你有可用的 RAM。
关于c - mmap 或 malloc 是否分配 RAM?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21119617/
我想了解 mmap 的工作原理。mmap 的用户级调用如下所示。 void *mmap(void *addr, size_t len, int prot, int flags, int
我正在做一个Bottle驱动程序,我使用 yield 关键字和 mmap.mmap 对象在输出流中发送多个映射文件,如以下代码所示: for mapping in mappings: yield
我来自 C++/RAII 世界。 所以我对何时以及如何调用 mmap.close() 感到困惑[不是 file.close()]。 或者,根本不调用它?会不会漏气? 至于来自 document 的示例
我正在我的大学上操作系统类(class),我们的任务之一是使用 mmap 实现简单的 malloc。现在我开始工作了,我尝试使用 valgrind 来检测遗留的任何错误。不管是否释放内存,valgri
有谁知道 mmap(2) 和 mmap(3) 的区别是什么?手册第 3 节被描述为“本章描述了除第 2 章中描述的实现系统调用的库函数之外的所有库函数。” mmap(3) 不执行系统调用吗? 阅读这两
我不知道我在理解mmap时错过了哪些知识。我就是想不通。但让我这样问我的问题: 我有很多(例如 3 个)文件 block ,其大小分别为 s1、s2、s3。 s1、s2 和 s3 均小于 Mmap (
在 Linux 下: #free -m total used free shared buffers cachedMem:
我正在尝试将 C 库(beaglebone PRU 驱动程序 prussdrv.c)与 Python 连接。我想要访问的特定函数返回一个 mmap 指针,如下所示: int __prussdrv_me
当我调用mmap时: ptr = mmap(NULL, ...); 并要求系统提供一个缓冲区并将文件映射到其中,然后使用 再次调用 mmap ptr2 = mmap(ptr, ...); 尝试
在 Android 上用 Java 内存映射一个大文件效果很好。但是当映射总数超过 ~1.5GB 时,即使有多个映射调用,它也会失败: mmap failed: ENOMEM (Out of memo
我在具有 64G 内存和大量磁盘空间的 debian-64 上运行一个专门的数据库守护进程。它使用磁盘上的哈希表(mmaped)并通过定期 write() 调用将实际数据写入文件。当进行大量更新时,m
C++代码: #include #include #include #include #include using namespace std; #define FILE_MODE (S_I
我想处理一个由 4Kb block 组成的文件。 随着事情的发生,我将编写更多数据并映射新部分,取消映射我不再需要的部分。 当要映射的文件数据总量约为 4Gb 时,仅 4Kb 的 map() 是否太小
大家好,我正在尝试将下面的代码转换为 python(访问树莓派 1Mhz 计时器),我不知道什么时候要映射对象,我们需要 + TIMER_OFFSET (timer = (long long int
我所做的是一个垃圾收集器,使用mmap(2)为用户空间分配空间,这就要求最初分配时可以从任何地方开始,但是后面的分配地址应该是与之前的分配连续,如下所示: page_size = getpagesiz
众所周知,最重要的 mmap() 功能是在许多进程之间共享文件映射。但众所周知,每个进程都有自己的地址空间。 问题是内存映射文件(更具体地说,它的数据)真正保存在哪里,以及进程如何访问这些内存? 我的
什么限制了内存映射文件的大小?我知道它不能大于未分配地址空间的最大连续块,并且应该有足够的可用磁盘空间。但是还有其他限制吗? 最佳答案 您太保守了:内存映射文件可能大于地址空间。 查看 内存映射文件的
如果我使用 mmap 来编写 uint32_t,我会遇到大端/小端约定的问题吗?特别是,如果我在 big-endian 机器上写入一些数据 mmap,当我尝试在 little-endian 机器上读取
所以,对于我最后一年的项目,我使用 Video4Linux2 从相机中提取 YUV420 图像,将它们解析为 x264(本地使用这些图像),然后通过 Live555 将编码流发送到 RTP/RTCP通
是 mmap在它们的效果中调用原子? 也就是说,是否由 mmap 进行了映射更改以原子方式出现在访问受影响区域的其他线程中? 作为试金石,请考虑您执行 mmap 的情况。在一个全为零的文件中(来自线程
我是一名优秀的程序员,十分优秀!