我读到,当您尝试使用 malloc() 分配的字节数超过 RAM 中可用的字节数时,它会分配虚拟内存
首先,这是不正确的。您总是分配虚拟内存。此虚拟内存映射到物理内存 (RAM) 或交换空间上的某个区域。如果交换空间 + 物理内存小于 100 GB,您的分配将失败。此外,libc
如果设置了一些(可编程的)限制,实现可能无法分配如此大的数量。
但我有一个奇怪的任务是在 htop 工具中为进程显示 100gb 的虚拟内存。据称可以通过单行代码实现。
是的,如果您只需要这么多虚拟内存,您可以保留内存但不提交。您可以阅读如何将mmap
(*NIX) 或VirtualAlloc
(Windows) 用于相同的目的。
当你保留一个特定的虚拟地址范围时,你告诉操作系统你打算使用这个范围,所以其他代码不能使用它。但这并不意味着您可以实际使用它。这也意味着它不需要 RAM/Swap 支持。因此,您将能够保留任意大的数量(当然,在您的 64 位系统上少于 2^48 字节)。
虽然我不确定是否htop
会将其包含在它显示的值中,但您必须尝试一下。
如果这确实没有增加您的虚拟内存计数,您可以将其映射到文件,而不是匿名映射。这可能会在您的系统上创建一个 100 GB 的文件(假设您有那么多空间),但您甚至应该能够读取/写入它。
以下代码可以在 linux 上使用 -
int fd = open("temp.txt", O_RDWR | O_CREAT);
void* addr = mmap(NULL, 100 * GBS, PROT_WRITE | PROT_READ, MAP_PRIVATE, fd, 0);