使用libc++,在公共部分找到std::shared_ptr::make_shared()静态成员函数。当我已经为std::shared_ptr的专门化定义了类型别名时,这是非常方便的:
using T = int;
using P = std::shared_ptr< T >;
auto p = P::make_shared(123); // <=> std::make_shared< T >(123)
static_assert(std::is_same< decltype(p), P >::value);我担心标准遵从性,因为来自可信源的文章(1,2)没有提到静态成员函数make_shared of std::shared_ptr。
目前使用该功能是否有问题?为什么?
发布于 2016-01-28 23:42:12
在使用这个静态make_shared成员函数时,您依赖于g++ /其标准库的特定于实现的扩展,正如您已经知道的那样。为了从中获得一点好处,我宁愿保持代码的可移植性,并使用std::make_shared。
对于您提到的情况,即使用复制或从现有构造函数中移动构造函数来构造一个新对象,我可以建议另一种方法(未经测试;为了实现C++11-兼容性,您必须添加一个尾部返回类型):
template <typename T>
auto share_ptr_to_new(T&& v) {
using T2 = typename std::remove_reference<T>::type;
return std::make_shared<T2>(std::forward<T>(v));
}在上面的例子中,您可以只编写auto p = share_ptr_to_new(123)。
发布于 2016-01-28 23:33:40
FWIW,有
template<class T, class... Args> shared_ptr<T> make_shared(Args&&... args);作为非会员的职能。
您应该能够使用std::make_shared而不是std::shared_ptr::make_shared。
https://stackoverflow.com/questions/35074037
复制相似问题