为什么我从未在此程序中看到Console中的Hello文本?

这是我在OS X Yosemite上运行的代码

int main(int argc, char *argv[]){ while (1) { srand(time(NULL)); int r = rand(); printf("Allocating\n"); int *pi = malloc(5000000 * sizeof(int)); if(pi==NULL){ printf("Hello"); } memset(pi, r, 5000000 * sizeof(int)); } } 

所以这个程序最终停止运行,Console中的最后一行我看到:

分配

分配

分配

被杀:9

Korays-MacBook-Pro:hello2 koraytugay $

如果malloc在这种情况下不返回NULL,它什么时候会这样做? 我的理解是这里发生了内存分配问题,但为什么不打印“Hello”?

如果你的内存需求超过可用内存,Linux将终止程序,使malloc永远不会返回NULL。

您可以使用echo 2> / proc / sys / vm / overcommit_memory关闭此function。

我怀疑printf为输出排队“Hello”,然后尝试使用空指针进行memset,并且在排队“Hello”处理之前进程被杀死。 您可以在Hello(fflush)之后尝试刷新标准输出。