在C中进行二维指针阵列打印后继续崩溃

时间:2013-01-09 14:29:57

标签: c

在下面的代码中,我在最后一个for循环后继续崩溃。我无法通过调试Netbeans来解决.. for循环工作,并打印我想要打印但然后程序崩溃而不是成功终止。你能帮忙吗(我知道获取,我会尽快尝试fgets)??

代码:

#include<stdio.h>
#include<stdlib.h>
#include<string.h>


int main()
{
    char *str,**string,buffer[50],temp[2];
    int i,j,size,counter;
    size=1;

    string=(char**) calloc(size,sizeof(char*));
    for (i=0; i<size; i++) string[i]=(char*)malloc(50*sizeof(char));

    printf("\nGimme strings, terminate input with x");
    i=0;
    gets(string[i]);
    temp[0]=120;//x
    temp[1]='\0';
    size=2;
    while(strcmp(string[i],temp)!=0)
    {
        string=realloc(string,size*sizeof(char**));
        i++;
        string[i]=malloc(50*sizeof(char));
        gets(string[i]);
        size++;
        counter++;
    }
    for(i=0; i<=counter; i++) printf("\n%s",string[i]);
    return 0;
}

2 个答案:

答案 0 :(得分:1)

counter循环

之前,

while未启动到0

并使用

string=realloc(string,size*sizeof(char*));

而不是

string=realloc(string,size*sizeof(char**));

你能详细描述一下你打算做什么,因为在你的代码中你正在分配指针数组,然后为数组中的每个指针分配内存,然后用realloc(string,2*sizeof(char**));删除几乎所有数组将删除几乎数组并只保留前2个指针。因此,您正在丢失指向已分配内存的指针,因此您无法再释放它们:

答案 1 :(得分:0)

  1. 计数器应在while循环之前设置为零。默认情况下,它不会设置为零。

  2. for look中的循环应排除counter

    for(i=0; i<counter; i++) printf("\n%s",string[i]);

  3. 通过调用free释放所有动态分配的内存。