C中奇怪的分段错误

时间:2010-11-21 12:46:32

标签: c segmentation-fault

int * mymalloc(int *array, int size){

    //PRINTS THE TIMES MYMALLOC IS CALLED. JUST FOR TESTING;
    printf("~~~~~~~~~~~~~~~TIME(S) MYMALLOC WAS CALLED:~~~~~~~~~~~~~~~ %d\n", i++);

    //checks
    if(size<1){
        printf("SIZE NOT VALID\n");
        return (int *) 0;
    }

    printf("MEMORY FREE JUST WHEN MYMALLOC() IS CALLED: %d\n", (*((BLOCK *)array[0])).size);

    BLOCK currentHeader = (*((BLOCK *)array[0]));

    do{
    printf("CURRENT HEADER STATUS: %d\n", currentHeader.status);
        if(currentHeader.status == 0){
            printf("ok\n");
            if(currentHeader.size >= size){

                currentHeader.status = 1;

                if(currentHeader.size - size < sizeof(currentHeader))
                    return &array[currentHeader.data];

                else{

                    BLOCK nextHeader;

                    array[size + currentHeader.data] =  (int)&nextHeader; 

                    if(currentHeader.nextb !=0){

                        (*currentHeader.nextb).previousb = &nextHeader;
                        nextHeader.nextb = currentHeader.nextb;
                    }

                    currentHeader.nextb = &nextHeader;
                    nextHeader.previousb = &currentHeader;

                    nextHeader.size = currentHeader.size - size - sizeof(nextHeader);//here?

                    nextHeader.data = currentHeader.data + size + sizeof(nextHeader); //here?
                    printf("NEXT HEADER DATA: %d\n", nextHeader.data );

                    nextHeader.status = 0;
                    currentHeader.size = size; //changing the currentHeader.size to the "size" given.

                    printf("%d\n", sizeof(currentHeader));
                    printf("%d\n", size + currentHeader.data);
                    printf("%d\n", nextHeader.size);


                    printf("i return\n");

                    return &array[currentHeader.data];


                }
            }
            //printf("NOT ENOUGH SIZE");
        }

        if(currentHeader.nextb !=0){
            printf("%d\n",*currentHeader.nextb);
            currentHeader = *currentHeader.nextb;

        }

    }while (currentHeader.nextb != 0);

    return (int *) 0;
     //printf("%d\n", (*((BLOCK *)array[0])).status ); 

}

好的家伙,当我运行这个程序时,实际上当我调用这个方法时,就像这样

mymalloc(testarray,50);

当我对该行printf("ok\n");发表评论时,我发现了一个细分错误 我的意思是它只是一个printf函数。怎么会影响记忆呢????? 你可以将它复制粘贴在你的机器上并尝试一下吗? 首先是printf("ok\n");
然后//printf("ok\n");

2 个答案:

答案 0 :(得分:0)

如果您对该行进行注释并且崩溃,则表示您的堆栈已损坏。因此,崩溃可能在任何“随机”点出现和/或消失而没有任何明显的原因(当然它不是随机的,但看起来似乎如此)。

您可以生成核心转储和/或使用valgrind和/或逐步调试吗?

答案 1 :(得分:0)

而不是“手工”这样做。我建议使用适当的工具,如valgrind或gprof。