我们知道程序在每次运行的时候地址都是不一样的,linux之所以有这样的设计也许是为了安全性考虑,不利于黑客的攻击。

 

我们看一个简单的程序:

 

#include 
#include 

int main(int argc, char* argv[])
{
    int first = 0;
    int *p = malloc(1024);
    printf("p=%p\n", p);

    return 0;
}

 

 

显然程序每次运行的地址都不一样!

 

那么有没有办法让相同程序每次运行的地址都一样呢?

 

看到这里你也许会问为什么让程序每次运行的地址都一样,这不违背OS设计的初衷了吗?是的,这的确违背 linux 内核设计的初衷。但是实际项目中难免不会遇到奇葩的需求,比如有些app由于历史的原因需要运行在指定地址上,那这时候就需要把地址空间随机化关掉。再比如遇到随机地址crash问题也可以用这种方法debug。

 

废话少说,我们看下地址空间随机化关掉的方法。

 

echo 0> /proc/sys/kernel/randomize_va_space
or
sudo sysctl -w kernel.randomize_va_space=0

 

关掉后我们看下该程序的测试结果:

 

 

哇!地址一样!