一行,fork炸弹,原理是不断fork新的进程,占用系统的cpu和内存资源,但不是总能成功,比如内核会将整个进程树干掉。
:(){:|:&};:
windows下:
%0 | %0
64位下,原理是64位有2^64字节虚拟内存,这远超过实际内存,所以下面循环执行到内存不够的时候,内核会调度swap分区(windows下对应swap文件),从而占光cpu和内存资源,同时也会卡磁盘io。未必一定成功,超出设定的交换分区大小上限后可能被内核干掉。
while(malloc(1))
==============update================
对评论区的统一回复,有人质疑while(malloc(1))的可行性,但由于大部分回复都靠不住脚,所以我本人也没有详细验证。
32位下是没有这个效果的,经测试64位下在卡顿一段时间之后会被内核干掉
分配时间很慢,这个是不存在的,malloc底层有sbrk包着,每满一个页,glibc才会向下調一次系统调用,而经测试,从程序运行到系统全部内存和swap被占用只要几秒钟
写时分配,经测试内存还是会被占满,看来写时分配没有起作用
内存压缩,我没有研究过这一块的论文,不过按我的理解,内存压缩应该是处理不了堆区内存的,如果大佬了解这一块,方便贴个出处。
最后是截图:
这是卡死前截到的图,源码中的while(1)不起实际作用,经测试,在卡死之后几秒钟内,这个程序会被内核kill掉。