Tag:

malloc()/ free()在哪里存储分配的大小和地址?

malloc()和free()在哪里存储分配的地址及其大小(Linux GCC)? 我已经读过一些实现将它们存储在实际分配的内存之前的某个地方,但是在我的测试中我无法确认。 背景,也许有人有另一个提示:我正在尝试分析进程的堆内存,以确定另一个进程中字符串的当前值。 访问进程堆内存并浏览它是没有问题的。 但是,因为字符串的值发生了变化,并且进程每次都会分配内存的新部分,所以字符串的地址会发生变化。 因为字符串有一个固定的格式,它仍然很容易找到,但经过一些更改后,旧版本的字符串仍然在堆内存中(可能已释放,但仍未被重用/覆盖),因此我无法分辨哪个字符串是当前字符串。 因此,为了仍然找到当前的一个,我想检查我在内存中找到的字符串是否仍然使用,通过比较其地址与malloc / free知道的地址。 ciao,Elmar

内存中的字符串文字是什么? 堆栈/堆?

可能重复: C字符串文字:它们去哪儿了? 我所知道的, 通常,指针必须由malloc()分配,并将分配给堆,然后由free()取消分配; 和 非指针(int,char,float等)将自动分配给堆栈,并且只要函数返回就不会分配 但是,从以下代码: #include int main() { char *a; a = “tesaja”; return 0; } 分配到哪里? 堆栈还是堆?