0

我有大量字符串需要存储在字符数组中,并且我需要能够遍历所有字符串。

此外,这些字符串不会改变,所以我希望矩阵是永久的,最好存储在头文件中。

谁能指出我正确的方向?

我在 C 中工作,不知道解决这个问题的最佳方法。

谢谢!

4

2 回答 2

2

标头中的变量定义可能不是一个好主意,请考虑替代方案:

// source.c contains
const char *const strings[] = {
    "string1", "string2", NULL 
};

// source.h contains
extern const char *const strings[];

// include source.h anywhere and loop through the strings like this:
for (const char *const *str = strings; *str != NULL; ++str)
    // use *str
于 2012-08-16T23:00:20.047 回答
0

尝试声明一个两级指针:

   #define NUMBER_OF_ROWS 10
   #define MAX_NUMBER_OF_CHARS_IN_STRING 255

   char *strings = (char**)calloc(NUMBER_OF_ROWS * sizeof(char));
   const char copy_string[] = "default string";

   for(int i = 0; i < NUMBER_OF_ROWS; i++)
   {
      strings[i] = (char*)calloc(MAX_NUMBER_OF_CHARS_IN_STRING);
   }

   for(int i = 0; i < NUMBER_OF_ROWS; i++)
   {
      strcpy(strings[i], copy_string);
   }

这是假设您使用的是 ANSI C

于 2012-08-16T23:04:37.690 回答