为什么同样的代码每次运行时给出不同的地址?

Why does same code gives different addresses each time it runs?

每次我 运行 代码时,我都会得到不同的输出值。当堆和堆栈地址固定时,为什么 malloc return 是不同的地址? 我希望它每次都从堆顶和 return 开始分配一个固定地址。堆栈也是如此。

#include <stdio.h>
#include <stdlib.h>

int main(){
    int *ptr = malloc(128);
    int a;
    printf("%p %p\n", ptr, &a);
    return 1;
}

堆和栈地址不固定。某些系统使用 address space layout randomization 故意改变地址,以便攻击者无法使用可预测的地址来进行攻击。