是否可以进行只读可复制(通过引用)shared_ptr?
Is it possible to do read-only copiable (by reference) shared_ptr?
我正在尝试创建一个在多个实例之间共享的只读 shared_ptr。 None 个实例应该能够修改指针对象的内容。但是这些实例应该能够在未知的时期内复制它。
a const std::shared_ptr<T>
不能轻易存储在属性引用中,因为它必须由构造函数定义。 (根据定义,const 引用是常量)
我做了一个包装器class
template<class T>
class const_shared_ptr
{
public:
const_shared_ptr(std::shared_ptr<T> ptr)
{
m_ptr = ptr;
}
const T* get() const
{
return m_ptr.get();
}
private:
std::shared_ptr<T> m_ptr;
}
这段代码干净吗?或者有更简单的方法吗?这看起来是一个非常简单的问题,但我想不出任何解决方案。
您可以从指向非 const 对象的共享指针初始化指向 const 对象的共享指针。
#include <memory>
void foo ()
{
auto v = std::make_shared <int> (10);
std::shared_ptr <int const> x = v;
// *x = 10; ERROR
}
我正在尝试创建一个在多个实例之间共享的只读 shared_ptr。 None 个实例应该能够修改指针对象的内容。但是这些实例应该能够在未知的时期内复制它。
a const std::shared_ptr<T>
不能轻易存储在属性引用中,因为它必须由构造函数定义。 (根据定义,const 引用是常量)
我做了一个包装器class
template<class T>
class const_shared_ptr
{
public:
const_shared_ptr(std::shared_ptr<T> ptr)
{
m_ptr = ptr;
}
const T* get() const
{
return m_ptr.get();
}
private:
std::shared_ptr<T> m_ptr;
}
这段代码干净吗?或者有更简单的方法吗?这看起来是一个非常简单的问题,但我想不出任何解决方案。
您可以从指向非 const 对象的共享指针初始化指向 const 对象的共享指针。
#include <memory>
void foo ()
{
auto v = std::make_shared <int> (10);
std::shared_ptr <int const> x = v;
// *x = 10; ERROR
}