我們知道程序在每次運(yùn)行的時候地址都是不一樣的,linux之所以有這樣的設(shè)計(jì)也許是為了安全性考慮,不利于黑客的攻擊。
我們看一個簡單的程序:
#include
#include
int main(int argc, char* argv[])
{
int first = 0;
int *p = malloc(1024);
printf("p=%pn", p);
return 0;
}
顯然程序每次運(yùn)行的地址都不一樣!
那么有沒有辦法讓相同程序每次運(yùn)行的地址都一樣呢?
看到這里你也許會問為什么讓程序每次運(yùn)行的地址都一樣,這不違背OS設(shè)計(jì)的初衷了嗎?是的,這的確違背 linux 內(nèi)核設(shè)計(jì)的初衷。但是實(shí)際項(xiàng)目中難免不會遇到奇葩的需求,比如有些app由于歷史的原因需要運(yùn)行在指定地址上,那這時候就需要把地址空間隨機(jī)化關(guān)掉。再比如遇到隨機(jī)地址crash問題也可以用這種方法debug。
廢話少說,我們看下地址空間隨機(jī)化關(guān)掉的方法。
echo 0> /proc/sys/kernel/randomize_va_space
or
sudo sysctl -w kernel.randomize_va_space=0
關(guān)掉后我們看下該程序的測試結(jié)果:
哇!地址一樣!