如何在 C 中管理字符串的动态数组



我有一个表示配方的结构。我不知道如何处理成分和程序,因为首先我不知道我需要多少内存来存储所有信息。 我以这种方式初始化了结构

struct _recipe
{
char name[50];
char** ingredients;
char diff[12];
int time;
int calories;
char** procedure;   
} recipe;

我试图以这种方式分配它们

recipe.ingredients = malloc(sizeof(char*) * 50);
recipe.procedure = malloc(sizeof(char*) * 50);
for(i = 0; i < 50; i++)
{
recipe.ingredients[i] = malloc(sizeof(char) * 30);
recipe.procedure[i] = malloc(sizeof(char) * 500);
}

但是在我尝试在它们内部编写后,我有一个奇怪的输出。打印出字符串后,我在进程结束时释放了内存,但是我的程序行为很奇怪,很可能是因为我得到了分段错误,但我实际上不明白为什么。那是因为我以错误的方式分配内存吗? 结束该过程后,它说返回值为 1。

这就是我取消引用指针的方式

for(i = 50; i >= 0; i--){
free(recipe.ingredients[i]);
}
for(j = 50; j >= 0; j--)
{
free(recipe.procedure[j]);
}
free(recipe.ingredients);
free(recipe.procedure);

在我尝试放置一个计数器来记住我使用了多少内存并且只释放未加密的内存后,我得到了这个输出

Apple pie
pø└
pø└
P└
P└
P└
PÃ└
PÃ└
PÃ└
PÃ└
└ÿc
└ÿc
└ÿc
pø└
pø└


















Easy
60 min
230 kcal
Mix milk and flour
P└
Bake them
P└
P└
P└
P└
P└
P└
P└
P└
P└
P└
P└
└ÿc
└ÿc
└ÿc

我知道我使用计数器以不好的方式取消引用,但是如果我编辑并取消引用所有 50 个元素,程序就会崩溃。无论如何,为了得到这个结果,我把它放在输入中: -名称: 苹果派 食材: 苹果 糖 面粉 牛奶 难度:简单 时间(分钟((用于准备(:60 热量: 230 程序:混合牛奶和面粉 添加苹果 烘烤它们 进程返回 1。我知道这是描述食谱的一种可怕方式,我只是在输入中放了几个字符串来显示它是如何结束的

这就是我的全部代码,我不知道如何摆脱错误

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
struct _recipe
{
char name[50];
char** ingredients;
char diff[12];
int time;
int calories;
char** procedure;   
} recipe;
int i = 0;
int j = 0;
char sentinel[] = "yes";
char stop[] = "yes";
char space = 'n';
int counter = 0;
int total = 0;
recipe.ingredients = malloc(sizeof(char*) * 50);
recipe.procedure = malloc(sizeof(char*) * 50);
for(i = 0; i < 50; i++)
{
recipe.ingredients[i] = malloc(sizeof(char) * 30);
recipe.procedure[i] = malloc(sizeof(char) * 500);
}

printf("Put the name of recipe:n");
fgets(recipe.name,30,stdin);
do{
printf("Put the ingredient:n");
fgets(recipe.ingredients[j],30,stdin);
j++;
counter++;
printf("Do you want to continue? (yes/no)");
gets(sentinel);
} while(strcmp("yes",sentinel) == 0);

printf("Put difficulty (Easy Medium Hard):n");
fgets(recipe.diff,11,stdin);
printf("Put time for preparation(in minutes):n");
scanf("%d", &recipe.time);
space = getchar();
printf("Inserisci l'apporto calorico:n");
scanf("%d", &recipe.calories);
space = getchar();
i = 0;
do{
printf("Put the procedure:n");
fgets(recipe.procedure[i],1000,stdin);
i++;
total++;
printf("Do you want to continue? (yes/no)n");
gets(stop);
} while(strcmp("yes", stop) == 0);


printf("%s", recipe.name);
for(i = 0; i < counter; i++)
{
printf("%s", recipe.ingredients[i]);
}
printf("%sn", recipe.diff);
printf("%d minn", recipe.time);
printf("%d kcaln", recipe.calories);
for (j = 0; j < total; j++)
{
printf("%s", recipe.procedure[j]);
}
for(i = 49; i >= 0; i--){
free(recipe.ingredients[i]);
}
for(j = 49; j >= 0; j--)
{
free(recipe.procedure[j]);
}
free(recipe.ingredients);
free(recipe.procedure);
return 0;
}

你的代码是正确的,也许这是你取消引用的方式?

以下作品:

for(int i = 0; i < 50; i++)
{
for(int j = 0; j < 30; j++){
recipe.ingredients[i][j] = 'a';
}
}
printf("Hello %c", recipe.ingredients[3][4]);

如果您发布如何取消引用的代码,那么我们可以进一步帮助您。

相关内容

  • 没有找到相关文章