Parallel of std::reference_wrapper for std::shared_ptrs
Parallel of std::reference_wrapper for std::shared_ptrs
如果要将引用绑定到函数f
,可以使用std::bind(f, std::ref(x))
。在这种情况下,f
获取引用或进行复制。
现在我有一个函数void g(T & t)
。我想将输入参数绑定到std::shared_ptr<T> mySharedPtr
,如下所示:std::bind(g, mySharedPtr)
。这将保证mySharedPtr
的数据的生存期至少与绑定一样长。但由于g
采用了引用,因此这不会进行类型检查。
是否有类似于std::ref
的东西,在将std::shared_ptr
传递到g
之前先取消引用它?如果没有,我能自己做一个吗
(如果你用Lambda给出答案,请也包括一个没有Lambda的,因为我的编译器不支持它们。)
编辑:std::bind(g, std::ref(*mySharedPtr))
不工作,因为它失去了std::shared_ptr
的寿命保证。
您似乎可以创建一个deref()
函数,该函数将创建一个对象,在转换时取消引用看起来像指针的东西:
template <typename P>
class pointer_wrapper {
P ptr;
public:
pointer_wrapper(P p): ptr(p) {}
operator decltype(*std::declval<P>())&() {
return *ptr;
}
};
template <typename P>
pointer_wrapper<P> deref(P p) {
return p;
}
最好将转换作为成员模板,以允许更多的转换。
相关文章:
- 使用std::multimap迭代器创建std::list
- C++中std::resize(n)和std::shrink_to_fit之间的区别
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 如何导出包含具有"std::unique_ptr"值的"std::map"属性的
- 从持续时间构造std::chrono::system_clock::time_point
- std::具有相同基类的类的变体
- std::向量与传递值的动态数组
- 使用std::vector的OpenCL矩阵乘法
- std::map<struct,struct>::find 找不到匹配项,但是如果我循环通过 begin() 到 end(),我在那里看到匹配项
- std::condition_variable::wait()如何评估给定的谓词
- 如何获取std::result_of函数的返回类型
- std::原子加载和存储都需要吗
- 将对象移动到std::shared_ptr
- POCO::PostgreSQL:如何将std::vector支持添加到`Binder::bind`
- 使用一个考虑到std::map中键值的滚动或换行的键
- 如何从 std::atomic 中提取指针 T<T>?
- 为什么 std::unique 不调用 std::sort?
- 使用std::函数映射对象方法
- 可组合的lambda/std::函数与std::可选