- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
这个练习让我看看如果接下来的程序中分配的内存块小于 1MB 会发生什么:
#include <stdio.h>
#include <stdlib.h>
main()
{
int MB=0;
while(malloc(1<<20))
++MB;
printf("Allocated %d MB total\n",MB);
}
我笔记本上的结果是
Allocated 3056 MB total
比起我这样修改程序:
#include <stdio.h>
#include <stdlib.h>
main()
{
int MB=0;
while(malloc(1<<19))
++MB;
printf("Allocated %d MB total\n",MB/2+MB%2);
}
结果是
Allocated 3045 MB total
我自己改的程序对吗?为什么结果小于 3056MB?
最佳答案
是的,你的程序没问题。 (尽管总是将兆字节数四舍五入有点不标准。)
当您调用 free
时,您不会告诉它您要释放的 block 有多大。这意味着内存管理系统必须知道每个 block 有多大。这意味着它必须将该信息存储在某个地方。由于它不能将信息存储在内存块内,因此必须将其存储在 block 外,这通常意味着实际分配的内存比请求的多一些。例如,它实际上可以分配一个比请求的 block 大 size_t
的 block ,将 block 大小存储在开头,然后告诉您该 block 在大小之后开始.
大多数 malloc
实现都会在页面边界上进行大量分配(通常一个页面是 4K)。一种方法是为每次分配浪费整个页面,仅将页面用于单个 size_t 值。这看起来很糟糕,但如果你要求即使是半兆字节,一个页面也不到分配大小的 1%,而浪费总内存的 1% 并不是那么糟糕。
假设您的 malloc 这样做了。当您分配 1MB 的 block 时,您设法分配了其中的 3056 个。如果每个分配比请求大一个 4k 页面,则隐藏分配将为 3056*4k,或略小于 12 兆字节。 (实际上它略小于 12 mebibytes ,但是当我指的是 mebi 时,我将继续说 mega。)所以可用的总内存应该是 3068 MB。
当您将其更改为分配 ½MB block 时,您设法分配了至少 3045*2 - 1 个(假设 MB 数向上舍入)。那是 6089 个额外页面,大约 23.8 MB,加上分配的 3044.5 MB,总共大约 3068.3 MB。
这些都不能证明您的 malloc 以这种方式工作,但它至少显示了一种可能的机制。
关于c - 书中的内存分配练习称为 "Expert C programming",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24051827/
我的英语很差,抱歉 这是我的结构: bookstore ---author(app1) ---book(app2) 或者在代码中: from django.db import models from
我对antlr 的理解停留在非常基础的层面。浏览 Parr 博士的“权威 ANTLR 4 引用”。在第 4.2 节“使用访问者构建计算器”中列出了以下语法: grammar LabeledExpr;
我对antlr 的理解停留在非常基础的层面。浏览 Parr 博士的“权威 ANTLR 4 引用”。在第 4.2 节“使用访问者构建计算器”中列出了以下语法: grammar LabeledExpr;
我正在学习 1.1.0 的 rust book 教程,但尝试运行他们的代码时出现错误。 我有以下内容: extern crate rand; use std::io; use std::cmp::Or
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题? Update the question所以它是on-topic对于堆栈溢出。 10年前关闭。 Improve this qu
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我的帖子是书的代码。 void qsort(void *lineptr[], int left, int right, int (*comp)(void *, void *)); /*Why it
考虑到 Fluent NHibernate 已经有一段时间了,我想应该会有一本书可以买到,所以我在亚马逊和谷歌中搜索,但没有关于 fluent nhiberanet 的书籍。我是对的还是这本书已经存在
考虑到 DocBook 格式的书可以以“模块化”的方式完成,我希望我可以用 AsciiDoc 做类似的事情,并将章节和第一级部分拆分到单独的文件中。不幸的是,文档没有提及这一点。到目前为止,我看到的唯
已关闭。此问题旨在寻求有关书籍、工具、软件库等的建议。不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以
我目前正在使用 Jquery 使用 turn.js 制作一本书,进展顺利,但我需要一点帮助。你看,我正在尝试制作一本精装期刊类型的书,就像此处显示的示例一样 http://www.turnjs.com
我正在阅读 Bjarne S 的 C++ 编程语言。 在第 77 页,第 4.8 节中,我发现了这一点: "枚举器可以用常量表达式初始化(§C.5) 的整数类型 (§4.1.1)。这枚举的范围包含向上
为什么当我输入由空格分隔的字符串(在 while 循环之外)并且我尝试在屏幕上打印它们时,只有我输入的第一个出现,而在这个 while 循环中(见代码)它打印所有这些一个? //this one pr
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我正在读这本书并被困在这里: public static class EventArgExtensions { public static void Raise(this TEventArgs
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
我正在尝试使用 xlwt 创建具有多个选项卡的输出文件(.xlsx 格式)。我的Python版本号是2.7,IDE是Aptana Studio 3。 我以前使用过 xlwt 包,在相同的环境下执行相同
如何使用 Xcode 或 macOS 打开 Swift Playground Book?当我打开它时,我得到了这个: 最佳答案 在 Xcode 上,转到 Navigate > Reveal in Pr
嗨,我对 php 很陌生,我正在阅读 Murach PHP 书。我在单击类别部分中的链接时遇到问题,因为当它单击该链接时,它会广告 ?category_id=3 但问题是它在 add_product.
我是一名优秀的程序员,十分优秀!