我们知道程序在每次运行的时候地址都是不一样的,linux之所以有这样的设计也许是为了安全性考虑,不利于黑客的攻击。
我们看一个简单的程序:
#include
#include
int main(int argc, char* argv[])
{
int first = 0;
int *p = malloc(1024);
printf("p=%p\n", p);
return 0;
}
![6ec1ef6e9e31a1d8ca81c258bef10c8c.png](https://i-blog.csdnimg.cn/blog_migrate/014fb21e5f3e6800db26e3dade14cf89.png)
显然程序每次运行的地址都不一样!
那么有没有办法让相同程序每次运行的地址都一样呢?
看到这里你也许会问为什么让程序每次运行的地址都一样,这不违背OS设计的初衷了吗?是的,这的确违背 linux 内核设计的初衷。但是实际项目中难免不会遇到奇葩的需求,比如有些app由于历史的原因需要运行在指定地址上,那这时候就需要把地址空间随机化关掉。再比如遇到随机地址crash问题也可以用这种方法debug。
废话少说,我们看下地址空间随机化关掉的方法。
echo 0> /proc/sys/kernel/randomize_va_space
or
sudo sysctl -w kernel.randomize_va_space=0
关掉后我们看下该程序的测试结果:
![b8e62b7447c426b3c63c6f4a8a587d1d.png](https://i-blog.csdnimg.cn/blog_migrate/e6e71235e2ad5cd7dde99bed78881f09.png)
哇!地址一样!
![7bf07402832252ac5496692390a2bf38.png](https://i-blog.csdnimg.cn/blog_migrate/d13e65f16cdda829763be684e7141e00.png)