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 中是空的。
我观察到如果我执行以下两项操作之一,该程序运行良好:
- 在 str2 中输入一个像 "Hello".
这样的小字符串
- 注释掉数据库相关的代码(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);
}
我对这个小程序有点困惑:
当我运行它时,它循环直到i = 999然后给出"corrupted double linked list"。在 func1 中,printf 显示 str 类似于 str2,但在 main str 中是空的。
我观察到如果我执行以下两项操作之一,该程序运行良好:
- 在 str2 中输入一个像 "Hello". 这样的小字符串
- 注释掉数据库相关的代码(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);
}