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

时间:2015-04-13 19:09:28

标签: c malloc osx-yosemite memset

这是我在 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”?

2 个答案:

答案 0 :(得分:3)

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

您可以使用echo 2>关闭此功能。的/ proc / SYS / VM / overcommit_memory。

答案 1 :(得分:0)

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