没有适用于 std::unique_ptr 的适当默认构造函数
No appropriate default constructor available for std::unique_ptr
这是我上一篇文章的延续。由于它已经关闭,我决定写一个新帖子。我删除了一半的代码以使其更具可读性。
我读过的一些帖子:
使用 SDL 的智能指针
是否可以将 SDL2 与智能指针一起使用?
关于SDL_Window和unique_ptr的几个问题
class cGraphics
{
public:
// Creator functions
std::unique_ptr<SDL_Window, decltype(&SDL_DestroyWindow)> Create_Window(int xWin, int yWin);
// ctor & dtor
cGraphics() : m_Window(nullptr, SDL_DestroyWindow) {}
cGraphics(int xWin, int yWin);
~cGraphics();
private:
std::unique_ptr<SDL_Window, decltype(&SDL_DestroyWindow)> m_Window;
};
cGraphics::cGraphics(int xWin, int yWin)
{
m_Window = std::move(Create_Window(xWin, yWin));
if (m_Window == nullptr)
{
throw "SDL_Window or SDL_Renderer not ready!";
}
}
cGraphics::~cGraphics()
{
IMG_Quit();
SDL_Quit();
}
std::unique_ptr<SDL_Window, decltype(&SDL_DestroyWindow)> cGraphics::Create_Window(int xWin, int yWin)
{
return std::unique_ptr<SDL_Window, decltype(&SDL_DestroyWindow)>(SDL_CreateWindow("SDL Window", SDL_WINDOWPOS_UNDEFINED, SDL_WINDOWPOS_UNDEFINED, xWin, yWin, SDL_WINDOW_SHOWN), SDL_DestroyWindow);
}
编译器抱怨:
'std::unique_ptr<SDL_Window,void (__cdecl *)(SDL_Window *)>::unique_ptr': no appropriate default constructor available
我知道当编译器找不到某些成员的默认构造函数时,通常会出现此错误。但是,事实并非如此,因为我明确声明了std::unique_ptr
的默认值。
如果编译器实际上抱怨SDL_Window
,这是一个不完整的类型(C 结构(,我该怎么办?
std::unique_ptr<SDL_Window, decltype(&SDL_DestroyWindow)>
不是默认可构造的。 这意味着在
cGraphics::cGraphics(int xWin, int yWin) ***
{
m_Window = std::move(Create_Window(xWin, yWin));
if (m_Window == nullptr)
{
throw "SDL_Window or SDL_Renderer not ready!";
}
}
当您到达***
部分时,编译器将尝试默认构造m_Window
,因为您没有在成员初始化列表中这样做。 从编译器到默认构造m_Window
的尝试是导致错误的原因。 我们可以通过将m_Window = std::move(Create_Window(xWin, yWin));
移出构造函数主体并将其放入成员初始化列表中来解决此问题,例如
cGraphics::cGraphics(int xWin, int yWin) : m_Window(Create_Window(xWin, yWin))
{
if (m_Window == nullptr)
{
throw "SDL_Window or SDL_Renderer not ready!";
}
}
如果您不想这样做,则可以委托给默认构造函数,然后像最初一样分配给m_Window
。 那看起来像
cGraphics::cGraphics(int xWin, int yWin) : cGraphics()
{
m_Window = Create_Window(xWin, yWin);
if (m_Window == nullptr)
{
throw "SDL_Window or SDL_Renderer not ready!";
}
}
以下是您如何定义unique_ptr
:
std::unique_ptr<SDL_Window, decltype(&SDL_DestroyWindow)> m_Window;
这意味着,它的构造函数必须使用 custome 删除器的实例调用,在您的情况下,函数SDL_DestroyWindow
- 请记住,您告诉指针什么是删除器的类型,而不是实际的删除器(在您的情况下是函数指针(。
要使此代码正常工作,您必须使用删除器实例正确构造指针,例如:
cGraphics::cGraphics(int xWin, int yWin) :
m_Window{Create_Window(xWin, yWin)} {...}
相关文章:
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 初始化具有非默认构造函数的std::数组项的更好方法
- 具有默认模板类型的默认构造函数的类型推导
- 如何使用非默认构造函数实例化模板化类
- 为什么不调用移动构造函数?(默认情况下只有构造器,没有别的)
- 有没有一种代码密度较低的方法来使用非默认构造函数初始化数组?
- 声明没有默认构造函数的字段
- 基类中的默认析构函数禁用子类中的移动构造函数(如果有成员)
- 没有默认构造函数作为模板参数的自定义比较器
- C++17 没有默认构造函数的地图放置(私有默认构造函数)
- 使用移动调用对等构造函数unique_ptr默认构造函数
- C++复制构造函数和默认构造函数
- 将向量从 N1 缩小到 N2 项,而不触发默认构造函数并仅使用 move 语义
- 构造函数默认公共和私有变量
- 类模板构造函数默认参数
- 构造函数默认参数
- C++模板构造函数默认参数
- 在c++中设置构造函数默认值
- c++构造函数默认参数
- C++构造函数默认值头文件