我有以下代码:
std::unordered_map<std::string, std::vector<std::unique_ptr<class EventTrigger>>> triggers;
if (triggers.end() == triggers.find(eventName)) {
triggers[eventName] = {};
}
这会导致有关使用已删除的 unique_ptr 构造函数的错误。另一方面,如果我这样做,一切都可以正常编译:
if (triggers.end() == triggers.find(eventName)) {
triggers[eventName] = std::vector<std::unique_ptr<class EventTrigger>>();
}
谁能解释为什么会这样?我认为空的初始化列表会导致一个空 vector 被分配给
triggers[eventName]
.
最佳答案
triggers[eventName] = {}
解析为 vector<T>::operator=(std::initializer_list<T>)
.此运算符需要将元素从初始值设定项列表复制到 vector 。triggers[eventName] = std::vector<...>()
解析为 vector<T>::operator=(vector<T>&&)
- 移动赋值运算符。这不需要复制任何元素,只需转移现有存储的所有权。
关于c++ - 无法将空的初始值设定项分配给 unique_ptrs 的 vector ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62124666/