例如:
struct test
{
char* ref_value1;
char* ref_value2;
int ref_value3; //reference value
};
申请字符串进行初始化
我们定义的字符串指针是没有内存空间的,需要先申请空间之后再赋值,于是就发现了这样一个字符串函数:strdup(str);
strdup()函数会计算出字符串的长度,然后调用malloc函数在堆上申请相应的空间,最后把字符串的所有字符复制到堆上
i.e.
char l[100], h[100]; //先申请空间作为临时内存
for (i = 0; i < n; i++) //input t2
{
int g = 0;
fscanf(input, "%s %s %d", l, h, &g); //input
/*printf("%s %s %d\n", l, h, g);*/
t[i].ref_value1 = strdup(l); //用 strdup转移
t[i].ref_value2 = strdup(h);
t[i].ref_value3 = g;
printf("%s %s %d \n", t[i].ref_value1, t[i].ref_value2, t[i].ref_value3);
}