如何使用元组转发unique_ptr
How to forward unique_ptr with tuple?
想象一个函数期望对std::unique_ptr的右值引用。
void foo(std::unique_ptr<int>&& a);
在我的现实世界示例中,有多个参数,因此我决定使用std::tuple<T&&>
右值引用将参数转发给它 - 所以std::forward_as_tuple
:
void forward_to_foo(std::tuple<std::unique_ptr<int>&&>&& t);
int main() {
forward_to_foo(std::forward_as_tuple(std::make_unique<int>(8)));
}
至于现在一切都很好。
我想"解压缩"这个元组时出现问题
void forward_to_foo(std::tuple<std::unique_ptr<int>&&>&& t)
{
foo(std::get<0>(t));
}
我在使用 c++4.9 的 gcc14 上收到此错误:
error: cannot bind 'std::unique_ptr<int>' lvalue to 'std::unique_ptr<int>&&'
foo(std::get<0>(t));
我的问题:这里有什么问题?为什么从右值引用的元组中std::get<I>(t)
返回左值?
这里有什么问题?
您需要std::move
才能从左值表达式中移动:
foo(std::move(std::get<0>(t)));
为什么从右值引用的元组
std::get<I>(t)
返回左值?
因为它返回对元组元素的左值引用。通常,返回左值引用的函数的结果是左值,因为它表示现有对象而不是临时对象。
相关文章:
- 为什么 std::unique 不调用 std::sort?
- CLANG 编译器 说:变量"PTR"可能未初始化
- 在以唯一ptr为值的C++映射中,动态内存何时会被销毁
- 将 ptr 传递给 ptr 到 A 作为参数传递给 A 的函数是不好的做法吗?
- 为共享 ptr 向量实现复制 c'tor?
- 字符和整数中 **(ptr+1) 的值差异
- C++:在不中断共享的情况下通过引用传递共享 PTR?
- 生成"unique"矩阵
- 如何将派生类从基 ptr 分配给 nlohmann::json
- 引用 std::shared:ptr 以避免引用计数
- 我对 std::unique(算法)C++有问题
- 为什么我不能在不进行任何转换的情况下将浮点数放入任何类型的 ptr 中?
- 在调用函数时,ptr** 和 ptr*& 之间是否有区别,或者首选C++?
- 另一种类型的智能ptr,比如具有弱refs的unique_ptr
- 尝试打印出 *ptr++ 的值,以了解它是如何工作的
- 如何控制共享 ptr 引用计数?
- std::shared_ptr::unique(),复制和线程安全
- 如何在C++03中用自定义谓词调用std::unique
- C++中的指针否定 (!ptr == NULL)
- C++14 unique_ptr并使用已删除的函数'std::unique-ptr' unique_ptr错误