我知道C(非常简洁)的数组初始化语法,比如
char arr[12] = {[0] = '\n', [4] = 'z'};
初始化数组中的一些特定成员,但有没有办法用字符串初始化数组的整个块?像这样:
char filename[12] = {[0..9] = "data/img/"};
是否有允许它的内置语法?或者我必须坚持memcpy():
char filename[strlen(basename) + 14];
memcpy(filename, "data/img/", 9);
memcpy(filename + 9, basename, l);
memcpy(filename + 9 + l, ".bmp", 4);
filename[l + 13] = '\0';
就是我现在拥有的; filename是有罪的字符数组,basename是变量字符串。
如果你想使用可变长度数组,初始化是不可能的,但为什么不使用snprintf
而不是memcpy
链与手工计算的偏移?
snprintf(filename, sizeof(filename), "data/img/%s.bmp", basename);
如果您不想手动计算VLA的维度,可以使用null目标调用snprintf
,并让它为您计算得到的字符串长度:
int len = snprintf(NULL, 0, "data/img/%s.bmp", basename);
char filename[len + 1];
(但请确保为两个调用使用相同的格式字符串和参数。)
(通知所有downvoters,这个答案写在编辑之前18分钟,添加了有关VLA的信息)
怎么了?
char arr[12] = "string";
这将使用"string"
的字符初始化元素0 .. 5,使用终止NUL初始化元素6,并将其余部分设置为将其余部分设置为NUL。
GCC有一个扩展,你可以用一个值初始化一个数组的范围,即
char arr[12] = {[1 ... 7] = 'a'};
但它不适用于字符串。
初始化器根本不适用于可变长度数组。在这种情况下使用sprintf
。
虽然这有效:
const char * basename = "base";
char filename[strlen(basename) + 14];
memcpy(filename, "data/img/", 9);
memcpy(filename + 9, basename, l);
memcpy(filename + 9 + l, ".bmp", 4);
filename[l + 13] = '\0';
这很复杂且容易出错。
对于“字符串”('\0'
终止的char
阵列),有str*()
系列函数。
像这样使用它:
char filename[strlen(basename) + 14];
strcpy(filename, "data/img/"); /* Sets filename including the final 0. */
strcat(filename, basename); /* Appends to filename including the final 0. */
strcat(filename, ".bmp"); /* ditto */