从initializer_list构造 std::map<T、<S>unique_ptr> 时出错
Error Constructing std::map<T, unique_ptr<S>> from an initializer_list
C2280 - 尝试引用已删除的函数 是我尝试从initializer_list构造 std::map> 时遇到的错误
我已经制作了最简单的代码(如下)来表示我的问题:
#include <string>
#include <map>
#include <memory>
using namespace std;
int main() {
map<string, unique_ptr<int>> MyMap{
{ "first" ,make_unique<int>(6) },
{ "second",make_unique<int>(22) },
{ "third" ,make_unique<int>(86) }
};
}
所以我意识到unique_ptr无法复制,但是既然make_unique返回了一个右值,那么unique_ptr不应该被移动到initializer_list吗?顺便说一句,如果我用shared_ptr替换unique_ptr,那么问题就解决了,但不是我正在寻找的解决方案,我想保留该初始化样式和unique_ptr。那么,在什么时候,对已删除函数的这种有问题的调用正在发生呢?有没有办法在不替换unique_ptr的情况下编译它?
可悲的是,这是std::initializer_list
对象的局限性之一。它们仅提供对其元素的const
访问,因此无法移出它们。最好的办法是以老式的方式初始化地图。
map<string, unique_ptr<int>> MyMap;
MyMap["first"] = make_unique<int>(6);
// etc.
如果您需要const
地图,您可以创建一个临时地图并从中移动:
const map<string, unique_ptr<int>> myMap = [] {
map<string, unique_ptr<int>> m;
m["first"] = make_unique<int>(6);
// etc.
return m; // RVO or implicit move
}();
你也可以使用 std::map
的范围构造函数,但是你必须自己为此编写一个特殊的迭代器类型,这会很烦人。
相关文章:
- 请解释这句话(cout<<1+int((a<b)^((b-a)&1) )<<endl
- 呼叫运营商<<临时
- 如何防止clang格式在流运算符调用之间添加换行符<<
- <<操作员在下面的行中工作
- EASTL矢量<向量<int>>连续的
- C - 创建矢量&lt; vector&lt; double&gt;&gt;矩阵具有分配而不是inizializ
- 为什么将此对向量&lt; map&lt; int,int&gt;&gt;中的地图进行更新.失败
- C :对矢量进行排序&lt; struct&gt;(结构有2个整数)基于结构的整数之一
- 明确的专业化“ CheckIntmap&lt;&gt;”实例化
- 什么是模板&lt;&gt;inline bla bla
- 编辑C Qlist&lt; object*&gt; gt;QML代码和一些QML警告中的模型
- eigen :: llt&lt;eigen :: matrixxd&gt;具有不完整的类型
- 错误,包括&lt; ctype&gt;在原子上使用C 11
- std::vector<;uint8_t>;当C++11/14启用时,手动复制而不是调用memcpy
- 如何加入向量&lt; int&gt;到C 中的单个INT
- 是std :: set&lt; std :: future&gt;不可能存在
- 是numeric_limits&lt; int&gt; :: is_modulo从逻辑上矛盾
- opencv 2.4.7在iOS错误背景_segm.hpp #include&lt; list&gt;未找到
- 在修改列表后,std :: list&lt; t&gt; :: end()的值是否会更改
- ///<评论></评论>在Visual Studio中