1

我是 C 新手,目前正在尝试获取字符串的子字符串。最终目标是我有一个字符串,其中包含一组数字,即 6218,并且我一直采用子字符串,因此我删除了最后一个数字,即:

6218
621
62
6

目前我正在硬编码我想要的长度,所以作为开始,我正在做一个 4 的子字符串,期望结果仍然是 6218。但是,当我在 gdb 中打印它时,它会在 62 处出现。

下面是我正在使用的代码。

char * performSearch(char * phoneNumber, int totalLookupNumberCount, numberLookupStruct *numberLookup, int maxCharsToLookup)
{
     int i;
    for (i = strlen(phoneNumber); i < maxCharsToLookup; i--)
    {
        char searchNumber[i+1];
        strncpy(searchNumber, phoneNumber, 4);
        searchNumber[i+1] = '\0';
    }
}

该函数由以下调用:

char * displayName = performSearch(phoneNumber, totalLookupNumberCount, numberLookup, maxCharsToLookup);

我正在逐步执行 GDB 中的代码,所以我做的第一件事就是在 strncpy 之后打印 searchNumber,因此实际上并没有使用循环。

我检查了通过的变量以及 strlen 返回的内容及其正确性

所以在上面的代码中,我希望 searchNumber 仍然是 6218,但它输出的是 62。还要注意 phoneNumber 作为 char * 传递给函数。

感谢您的任何帮助,您可以提供。

4

2 回答 2

1

做就是了

string[i]=0;

这将在指定点之后放置一个字符串结尾字符,切断字符串的其余部分。

于 2013-06-20T15:54:28.780 回答
1

测试for条件似乎错误:

for (i = strlen(phoneNumber); i < maxCharsToLookup; i--)

如果maxCharsToLookup大于,那么当变成负数strlen(phoneNumber)时,这个循环似乎会做一些时髦的事情。i如果maxCharsToLookup小于或等于strlen(phoneNumber),则循环永远不会开始。可能你需要这样的东西:

for (count = 0, i = strlen(phoneNumber);
     count < maxCharsToLookup && i > 0;
     ++count, --i)

strncpy()很难使用。如果源字符串的字符串长度比指定的复制长度短,它只会 NUL 终止目标字符串。这是一个很难记住的规则。此外,它总是会写入您在最后一个参数中指定写入的字节数。在您的代码中:

    char searchNumber[i+1];
    strncpy(searchNumber, phoneNumber, 4);
    searchNumber[i+1] = '\0';

如果i小于 3,strncpy()将超出您的缓冲区。这将导致未定义的行为。然后将缓冲区后面的字节设置为 NUL,这也是未定义的。你应该这样做:

    char searchNumber[i+1];
    strncpy(searchNumber, phoneNumber, i);
    searchNumber[i] = '\0';

我更喜欢使用snprintf(). 它总是 NUL 终止结果字符串。

#include <stdio.h>
#include <string.h>
int main () {
    char phoneNumber[] = "6218";
    for (int i = strlen(phoneNumber); i > 0; --i) {
        char searchNumber[i+1];
        snprintf(searchNumber, sizeof(searchNumber), "%s", phoneNumber);
        puts(searchNumber);
    }
    return 0;
}
于 2013-06-20T16:16:16.837 回答