strlen – 字符串的长度有时会增加1

我正在做一些C拼图问题。 在大多数情况下,我能够找到正确的答案,但有了这个答案,我遇到了问题。 我通过使用编译器知道正确的答案,但我不知道原因。

看看代码:

char c[] = "abc\012\0x34"; 

strlen(c)会使用标准C编译器返回什么?

当我期望的是3时,我的编译器返回4。

我认为是strlen()会搜索第一次出现的NULL字符但不知何故结果是比我预期的多一个。

知道为什么吗?

让我们写

 char c[] = "abc\012\0x34"; 

单个字符:

 char c[] = { 'a', 'b', 'c', '\012', '\0', 'x', '3', '4', '\0' }; 

您看到的第一个\0是八进制转义序列\012的开头,它延伸到以下八进制数字。

八进制转义序列在标准(N1570草案)的6.4.4.4节中规定:

八进制转义序列:
\ octal-digit
\ 八位数八进制数字
\ octal-digit八进制数字八进制数字

它们由反斜杠后跟一个,两个或三个八进制数字组成。 在该节的第7段中,给出了八进制和hex转义序列的范围:

7每个八进制或hex转义序列是可构成转义序列的最长字符序列。

请注意,虽然八进制转义序列的长度限制为最多三个八进制数字(因此"\123456"由五个字符组成, { '\123', '4', '5', '6', '\0' } ),hex转义序列具有无限长度

hex转义序列:
\x hex数字
hex转义序列hex数字

因此"\x123456789abcdef"只包含两个字符( { '\x123456789abcdef', '\0' } )。