Why no emplacement iterators in C++11 or C++14?(为什么在 C++11 或 C++14 中没有定位迭代器?)
问题描述
C++98 有 front_inserter
、back_inserter
和 inserter
,但在C++11 或 C++14 草案.是否有任何技术原因我们不能拥有 front_emplacer
、back_emplacer
和 emplacer
?
C++98 has front_inserter
, back_inserter
, and inserter
, but there don't seem to be any emplacement versions of these in C++11 or draft C++14. Is there any technical reason we couldn't have front_emplacer
, back_emplacer
, and emplacer
?
推荐答案
是否有任何技术原因我们不能拥有 front_emplacer、back_emplacer 和 emplacer?
Is there any technical reason we couldn't have front_emplacer, back_emplacer, and emplacer?
不,没有技术原因.作为证明,这里是 back_emplacer
的完整实现以及您的用例 1 的演示...
No, there is no technical reason. As proof, here is a complete implementation of back_emplacer
with a demo of your Use Case 1...
#include <iterator>
#include <vector>
#include <iostream>
template<class Container>
class back_emplace_iterator : public std::iterator< std::output_iterator_tag,
void, void, void, void >
{
protected:
Container* container;
public:
typedef Container container_type;
explicit back_emplace_iterator(Container& x) : container(&x) {}
template<class T>
back_emplace_iterator<Container>&
operator=(T&& t)
{
container->emplace_back(std::forward<T>(t));
return *this;
}
back_emplace_iterator& operator*() { return *this; }
back_emplace_iterator& operator++() { return *this; }
back_emplace_iterator& operator++(int) { return *this; }
};
template< class Container >
inline back_emplace_iterator<Container>
back_emplacer( Container& c )
{
return back_emplace_iterator<Container>(c);
}
struct Demo
{
int i;
Demo(int i) : i(i) {}
};
int main()
{
std::vector<int> x = {1,2,3,4,5};
std::vector<Demo> y;
std::copy(x.begin(), x.end(), back_emplacer(y));
for (auto d : y)
std::cout << d.i << std::endl;
}
可能的已知问题:operator=
的通用引用是否隐藏了隐式生成的复制/移动 operator=
?如果是这样,则需要以在重载解析中击败通用引用的方式明确定义这些.
Possible Known Issue: Does the universal reference of operator=
hide an implicitly generated copy/move operator=
? If so these need to be explicitly defined in a way that beats the universal reference in overload resolution.
这篇关于为什么在 C++11 或 C++14 中没有定位迭代器?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:为什么在 C++11 或 C++14 中没有定位迭代器?


基础教程推荐
- 管理共享内存应该分配多少内存?(助推) 2022-12-07
- 如何“在 Finder 中显示"或“在资源管理器中显 2021-01-01
- 为什么语句不能出现在命名空间范围内? 2021-01-01
- 为 C/C++ 中的项目的 makefile 生成依赖项 2022-01-01
- Windows Media Foundation 录制音频 2021-01-01
- 使用从字符串中提取的参数调用函数 2022-01-01
- 如何在不破坏 vtbl 的情况下做相当于 memset(this, ...) 的操作? 2022-01-01
- 从 std::cin 读取密码 2021-01-01
- 如何使图像调整大小以在 Qt 中缩放? 2021-01-01
- 在 C++ 中循环遍历所有 Lua 全局变量 2021-01-01