- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我注意到当涉及到字符串或字符数组时,std::end
将始终引用 null 终止符。我认为 std::end
应该指的是最后一个有效元素之后的数组末尾。 '\0'
不被认为是有效元素吗?它是数组的一部分。以下是一些全部返回 true 的测试:
#include <iostream>
int main()
{
std::string s("hello!");
auto s_end = *(s.data() + s.size() + 1);
std::cout << std::boolalpha << (*std::end(s) == s_end) << "\n"
<< (s_end == '\0') << "\n";
char buf[6 + 1];
std::copy(s.begin(), s.end(), &buf[0]);
auto buf_end = *(buf + s.size() + 1);
std::cout << (*std::end(buf) == buf_end) << "\n"
<< (buf_end == '\0') << "\n";
char test[3] = {'h', '\0', 'e'};
std::cout << (*std::end(test) == '\0');
return 0;
}
最佳答案
对于字符数组,std::end
确实指向数组中的最后一个字符。对于
char test[3] = {'h', '\0', 'e'};
指针std::end(test)
与test + 3
相同.取消引用它与评估 test[3]
相同.这是未定义的行为。在您的特定情况下,它恰好产生了 '\0'
.但总的来说,它可能会产生不同的值(value),或崩溃,或完全不同的东西。 std::end(test)
不指向'\0'
数组中索引 1 处的字符 test
!
请注意 std::end
对所有数组表现一致。也就是说,如果我们有一个数组 T a[N]
, 然后 std::end(a)
返回 a + N
,无论是否T
是char
或者a
的内容是什么是。它不会给你字符串的结尾;它给你数组的结尾。同样,返回值始终是 a + N
.没有异常(exception)!
对于 std::string
,有一个终止空字符,但它不被视为字符串的一部分。 (与其他字符不同,您不允许修改它,否则会出现未定义的行为。)如果您有
std::string s("hello");
然后 s[5]
将具有空字符的值,但正如我所说,它不被视为字符串的一部分:s
被认为有五个字符,而不是六个。最好想到std::string
因为根本没有被空终止。最后一个字符是 s[4]
具有值(value)'o'
, 和 std::end(s)
是刚刚过去的迭代器 std::begin(s) + 4
, 即 std::begin(s) + 5
.
这比看起来要微妙一些,因为标准在技术上不保证 std::end(s)
完全是可取消引用的,因此您不一定可以说它指向终止的 null。实际上,它确实指向终止 null,但取消引用它仍然是未定义的行为。
关于c++ - 字符串的 std::end 是否应该指向空终止符?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25925594/
我有一个用 0 填充的大字符数组。我从套接字读取传入文件并将其内容放入缓冲区中。我无法写入包含所有“\0”的缓冲区,因此我分配了一个具有正确大小的新缓冲区并进行写入。我使用这种方法来做到这一点: in
我正在创建一个程序,通过命令行逐字符读取文本文件的内容。 NULL 值是自动插入的还是我必须手动将其添加到文本文件中? 最佳答案 文本文件在现代平台上不需要有终止符。 (在某些遗留平台上,他们确实有一
我正在使用 this library在 Go 中(在 OSX 上)与 Windows DNS 服务器交互。 运行以下代码片段时,出现有关空终止符的错误。 $ ~/go/bin/winrm-dns-c
我正在使用 fprintf 将字符串附加到文档中,这是我有疑问的行: fprintf(win, bff[i - 2] != '\n' && bff[i - 2] != '\r' ? "\nmultis
所以我正在制作每个人都喜欢的有趣游戏“石头、剪刀、布”,除了 while 循环在停止之前重复 3 次之外,我一切正常。嗯,它确实重复了 3 次并停止,但第二次和第三次重复变量没有改变。看一下代码并告诉
我对 llvm 还很陌生,只在这里完成了在线教程:http://llvm.org/docs/tutorial/LangImpl1.html现在我想做自己的小语言,但遇到了一些问题。我想解析这个: (d
我的 C 双向链表实现似乎无法正常工作。我担心这可能是由于我对 C 中指针的粗略了解(来自对解释语言的无知)。当我运行此代码时,似乎 print_list() 会永远运行,即使它应该被 next 字段
这是我第一次在这里发帖,如果我做错了什么,很抱歉。 我有一个 C 程序,它分配一个池,然后在内存中存储一个字符数组“Hello World”,然后检索它。我的主要方法中的代码行之一是: store
我正在尝试将包含字符串集合的文本文件读取到对象数组中,但输入有问题。我收到一个错误,该错误会转到此处的 istream *_Str = _Elem(); // add terminating n
我有一个 const char* 指向十六进制格式的数据,我需要找到我正在检查的数据的长度 NUL-terminator 但是当\x00 出现时它检测到它作为 NUL 终止符返回不正确的长度。 我该如
我在可执行文件中包含的文件中有一些大型字符串资源。我使用以下命令将它们包含在可执行文件中。 *.S 允许 GCC 调用 as 来生成目标文件,而无需任何特殊处理。 ;; ca_conf.S
如果你将一个 char 指针指向你刚刚 malloc() 的内存块,并在位置 [0]、[1]、[2]、[3]、...、[n] 处向它提供字符malloc 已经在末尾提供了空终止符“\0”,还是我必须在
有没有更好的方法将字符串 vector 转换为字符 vector ,字符串之间的终止符为零。 因此,如果我有一个包含以下字符串的 vector "test","my","string",那么我想接收一
所以,operator[]没有直接说s[s.size()]必须是s[s.size()-1]之后的字符在内存中。它的措辞似乎是为了避免做出这种说法。 但是s.data()指出s.data()+k ==
我使用 std::string 来保存任意二进制数据 blob。它以这种方式工作,但效率稍低,因为它需要将空终止符添加到 blob 的末尾。 (C++11 规范是 c_str() 和 data() 相
我是一名优秀的程序员,十分优秀!