gpt4 book ai didi

c++ - 如何在只有 protected 或私有(private)构造函数的类上调用::std::make_shared?

转载 作者:塔克拉玛干 更新时间:2023-11-03 07:48:35 25 4
gpt4 key购买 nike

我的这段代码不起作用,但我认为意图很明确:

testmakeshared.cpp

#include <memory>

class A {
public:
static ::std::shared_ptr<A> create() {
return ::std::make_shared<A>();
}

protected:
A() {}
A(const A &) = delete;
const A &operator =(const A &) = delete;
};

::std::shared_ptr<A> foo()
{
return A::create();
}

但是编译的时候出现了这个错误:

g++ -std=c++0x -march=native -mtune=native -O3 -Wall testmakeshared.cpp
In file included from /usr/lib/gcc/x86_64-redhat-linux/4.6.1/../../../../include/c++/4.6.1/bits/shared_ptr.h:52:0,
from /usr/lib/gcc/x86_64-redhat-linux/4.6.1/../../../../include/c++/4.6.1/memory:86,
from testmakeshared.cpp:1:
testmakeshared.cpp: In constructor ‘std::_Sp_counted_ptr_inplace<_Tp, _Alloc, _Lp>::_Sp_counted_ptr_inplace(_Alloc) [with _Tp = A, _Alloc = std::allocator<A>, __gnu_cxx::_Lock_policy _Lp = (__gnu_cxx::_Lock_policy)2u]’:
/usr/lib/gcc/x86_64-redhat-linux/4.6.1/../../../../include/c++/4.6.1/bits/shared_ptr_base.h:518:8: instantiated from ‘std::__shared_count<_Lp>::__shared_count(std::_Sp_make_shared_tag, _Tp*, const _Alloc&, _Args&& ...) [with _Tp = A, _Alloc = std::allocator<A>, _Args = {}, __gnu_cxx::_Lock_policy _Lp = (__gnu_cxx::_Lock_policy)2u]’
/usr/lib/gcc/x86_64-redhat-linux/4.6.1/../../../../include/c++/4.6.1/bits/shared_ptr_base.h:986:35: instantiated from ‘std::__shared_ptr<_Tp, _Lp>::__shared_ptr(std::_Sp_make_shared_tag, const _Alloc&, _Args&& ...) [with _Alloc = std::allocator<A>, _Args = {}, _Tp = A, __gnu_cxx::_Lock_policy _Lp = (__gnu_cxx::_Lock_policy)2u]’
/usr/lib/gcc/x86_64-redhat-linux/4.6.1/../../../../include/c++/4.6.1/bits/shared_ptr.h:313:64: instantiated from ‘std::shared_ptr<_Tp>::shared_ptr(std::_Sp_make_shared_tag, const _Alloc&, _Args&& ...) [with _Alloc = std::allocator<A>, _Args = {}, _Tp = A]’
/usr/lib/gcc/x86_64-redhat-linux/4.6.1/../../../../include/c++/4.6.1/bits/shared_ptr.h:531:39: instantiated from ‘std::shared_ptr<_Tp> std::allocate_shared(const _Alloc&, _Args&& ...) [with _Tp = A, _Alloc = std::allocator<A>, _Args = {}]’
/usr/lib/gcc/x86_64-redhat-linux/4.6.1/../../../../include/c++/4.6.1/bits/shared_ptr.h:547:42: instantiated from ‘std::shared_ptr<_Tp1> std::make_shared(_Args&& ...) [with _Tp = A, _Args = {}]’
testmakeshared.cpp:6:40: instantiated from here
testmakeshared.cpp:10:8: error: ‘A::A()’ is protected
/usr/lib/gcc/x86_64-redhat-linux/4.6.1/../../../../include/c++/4.6.1/bits/shared_ptr_base.h:400:2: error: within this context

Compilation exited abnormally with code 1 at Tue Nov 15 07:32:58

这条消息基本上是说模板实例化堆栈中的一些随机方法从 ::std::make_shared 无法访问构造函数,因为它是 protected 。

但我真的想同时使用 ::std::make_shared 并防止任何人创建一个未被 ::std::shared_ptr 指向的此类对象。有什么办法可以做到这一点?

最佳答案

This answer可能更好,而且我可能会接受。但我也想出了一个更丑陋的方法,但仍然让所有内容仍然是内联的并且不需要派生类:

#include <memory>
#include <string>

class A {
protected:
struct this_is_private;

public:
explicit A(const this_is_private &) {}
A(const this_is_private &, ::std::string, int) {}

template <typename... T>
static ::std::shared_ptr<A> create(T &&...args) {
return ::std::make_shared<A>(this_is_private{0},
::std::forward<T>(args)...);
}

protected:
struct this_is_private {
explicit this_is_private(int) {}
};

A(const A &) = delete;
const A &operator =(const A &) = delete;
};

::std::shared_ptr<A> foo()
{
return A::create();
}

::std::shared_ptr<A> bar()
{
return A::create("George", 5);
}

::std::shared_ptr<A> errors()
{
::std::shared_ptr<A> retval;

// Each of these assignments to retval properly generates errors.
retval = A::create("George");
retval = new A(A::this_is_private{0});
return ::std::move(retval);
}

编辑 2017-01-06:我对此进行了更改,以明确表示这个想法可以清楚而简单地扩展到采用参数的构造函数,因为其他人正在按照这些思路提供答案并且似乎对这个。

关于c++ - 如何在只有 protected 或私有(private)构造函数的类上调用::std::make_shared?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33533453/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com