1

我在strncpy()复制所需长度的额外字符时遇到问题。我需要将 10 个最高有效位从一个字符串复制到另一个字符串(均为char*格式)。

较大变量的大小在直觉上并不重要,较小的变量仅在明显小于我需要的值时才会影响输出(我也不知道为什么会这样)。

my 中的 n 值strncpy()可能是导致问题的原因,但我不知道它为什么会这样。如果我没记错的话,目标字符串的长度 n 应该比数据长 1,以说明最后的空字符。

我的字符串根本没有这样的行为。设置n11,我收到以下输出:

00000111101100100100001110100000

00000111101

我想它只会复制 10 个字符,最后一个为空字符。增加n会产生相同的结果。

将 n 减少到 10 揭示了问题的核心:

00000111101100100100001110100000

0000011110@

我不知道它为什么会这样做,但是随着 n 的减小,它会继续这样做,直到n小得多(大约 8)。

这些是我的代码的相关行:

char line[11], hexAddr[8], binAddr[33], lv1Index[11];
    ...
strncpy(lv1Index, binAddr, 10);

lv1Index此之前未触及的位置,并且 binAddr 直接预先显示(在给定的输出中)。

添加的字符总是@,所以我不相信它是lv1Index预初始化的垃圾。

4

1 回答 1

3

一个 C++ 参考

如果在复制 num 个字符之前找到源 C 字符串的结尾(由空字符表示),则用零填充目标,直到总共写入了 num 个字符。

没有空字符隐式附加到目标的末尾,因此只有当源中 C 字符串的长度小于 num 时,目标才会以空字符结尾。

其他文档(MSDN手册页)也有类似的信息。

这意味着您应该将空终止符放在自己身上:

 lv1Index[10] = '\0';
于 2011-11-21T05:56:51.500 回答