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 = ¤tHeader;
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");
答案 0 :(得分:0)
如果您对该行进行注释并且崩溃,则表示您的堆栈已损坏。因此,崩溃可能在任何“随机”点出现和/或消失而没有任何明显的原因(当然它不是随机的,但看起来似乎如此)。
您可以生成核心转储和/或使用valgrind和/或逐步调试吗?
答案 1 :(得分:0)
而不是“手工”这样做。我建议使用适当的工具,如valgrind或gprof。