C 编程:为字符串动态分配的内存和 sqlite3_open 不能一起工作

C programming: dynamically allocated memory for string and sqlite3_open doesn't work together

我对这个小程序有点困惑:

当我运行它时,它循环直到i = 999然后给出"corrupted double linked list"。在 func1 中,printf 显示 str 类似于 str2,但在 main str 中是空的。

我观察到如果我执行以下两项操作之一,该程序运行良好:

  1. 在 str2 中输入一个像 "Hello".
  2. 这样的小字符串
  3. 注释掉数据库相关的代码(sqlite3_open and sqlite3_close);

谢谢!

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

sqlite3 *conn;

void func1 (char* str)
{
   char str2[3000];
   strcpy (str2, "dawNUkjhkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkdwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwaauhfuiahfsuehusehfseihfseifjhselfjslkejfklsejfksejksejfeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeejjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjUkjhkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkdwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwaauhfuiahfsuehusehfseihfseifjhselfjslkejfklsejfksejksejfeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeejjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjUkjhkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkdwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwaauhfuiahfsuehusehfseihfseifjhselfjslkejfklsejfksejksejfeeeeeeejjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjdawfa");

   // strcpy (str2, "Hello\n");

   str = (char*) realloc (str, sizeof (char) * (strlen (str2) * 2));
   strcat (str, str2);

   printf ("func1:  %s\n", str);

}

int main ()
{
    int dataBaseResult;
    char* str = malloc (sizeof (char));

    /* open database */
    dataBaseResult = sqlite3_open ("magazin.db", &conn);
    if (dataBaseResult != 0)
    {
       fprintf (stderr, "Problem %s\n", sqlite3_errmsg (conn));
    }
    else 
    {
       printf ("Opened succesfully!\n");
    }


    for (int i = 0; i < 1000; i++)
    {
       printf ("main:  %d\n", i);           

       strcpy (str, "");

       func1 (str);

       printf ("main:  %s\n", str);
    }


    /* close database */
    sqlite3_close (conn);

    return 0;
}

您正在分配 1 个字节的 sizeof char。 malloc sizeof char * 3001

更改 func1 以正确更新传入的指针。像这样:

void func1 (char **str)
{
    char str2[3000];
    char *tmp = NULL;
    strcpy (str2, "...");

    tmp = (char*) realloc (*str, sizeof (char) * (strlen (str2) * 2));
    if (!tmp) {
        *str = tmp;
    }
    strcat (*str, str2);

}