存储指向 strsep() return 值的指针
Storing pointers to strsep() return values
当我使用 strsep() 循环访问字符串的标记时,存储指向这些标记的指针并在以后引用它们是否安全?示例:
char str[] = "some word tokens";
char *sameStr = str;
char *token, *old1, *old2;
token = strsep(&sameStr, " ");
old1 = token;
token = strsep(&sameStr, " ");
old2 = token;
token = strsep(&sameStr, " ");
printf("%s\n%s\n%s\n", token, old1, old2);
似乎 strsep() 总是修改原始字符数组,在每个标记后插入空字符。如果是这样,我应该安全存储并稍后使用 old1 和 old2 指针,对吗?另外,我使用 sameStr 会导致任何问题吗?由于 strsep() 需要受限的 char** 类型,我无法直接使用指针 str。
在原始字符串超出范围之前,存储的指针将一直有效。在此之前,您可以根据需要访问它们。使用 sameStr
应该不会造成任何问题。
当我使用 strsep() 循环访问字符串的标记时,存储指向这些标记的指针并在以后引用它们是否安全?示例:
char str[] = "some word tokens";
char *sameStr = str;
char *token, *old1, *old2;
token = strsep(&sameStr, " ");
old1 = token;
token = strsep(&sameStr, " ");
old2 = token;
token = strsep(&sameStr, " ");
printf("%s\n%s\n%s\n", token, old1, old2);
似乎 strsep() 总是修改原始字符数组,在每个标记后插入空字符。如果是这样,我应该安全存储并稍后使用 old1 和 old2 指针,对吗?另外,我使用 sameStr 会导致任何问题吗?由于 strsep() 需要受限的 char** 类型,我无法直接使用指针 str。
在原始字符串超出范围之前,存储的指针将一直有效。在此之前,您可以根据需要访问它们。使用 sameStr
应该不会造成任何问题。