问题描述
在使用 std::transform
和 back_inserter
之前检查向量是否为空是个好主意,否则不会发生任何错误,因为 vector.begin()
将与 {{ 相同1}} 并且不会在新向量中插入任何内容?
解决方法
这是不需要的。如果 empty()
是 true
,那么 begin() == end()
和 transform
将成为非操作,因为它在 [begin,end)
所有 std
算法都是空容器上的 noops。唯一有问题的是 std::minmax(std::initializer_list)
之类的东西,它要求它是非空的;它不返回迭代器,而是返回元素。
(请注意,在这种情况下,它需要一个列表,该列表通常就在 {}
中,因此如果它为空,通常很明显。)
在调用它们之前测试空的唯一原因应该是:
-
您将要对数据连续执行许多此类算法。
-
您希望能够通过断言、断点或日志轻松检测是否传递了一个空容器。
-
除了“什么都不做”之外,处理空数据的方式有些不同(注意:这通常但并非总是表明您的设计存在缺陷)。