定义结构中没有默认构造函数的类

Defining a class with no default constructor inside a struct

本文关键字:构造函数 默认 结构 定义      更新时间:2023-10-16

我遇到了一个问题,我必须在嵌入式系统中使用C++库。该库(用于微控制器的Tensorflow Lite(专为嵌入式系统而设计,并且没有malloc/free,但是使用它的示例定义了堆栈上的所有内容,并且没有可用的默认构造函数。

在我的应用程序中定义堆栈不起作用,因为我需要能够在一个函数中初始化它,然后退出。我需要的是能够分配一个内存区域(使用我自己的分配器(,其中包含我需要的所有内容,然后初始化该内存区域中的所有内容。

我试图将其归结为一个最低限度的例子:

// This is a third party library
class OtherClass {};
class MyClass {
private:
OtherClass &c;
public:
MyClass(OtherClass &c) : c(c) {};
};
// My code
typedef struct {
OtherClass otherClass;
MyClass myClass;
} MyAllocatedData;
char dataIsSomewhere[sizeof(MyAllocatedData)];
MyAllocatedData *pData = (MyAllocatedData *)dataIsSomewhere;
int main() {
// dataIsSomewhere gets allocated somewhere on demand
// now we want to initialise everything
pData->myClass = MyClass(pData->otherClass);  
return 0;
}

编译失败,并显示:

test.cpp: In function ‘int main()’:
test.cpp:20:45: error: use of deleted function ‘MyClass& MyClass::operator=(MyClass&&)’
pData->myClass = MyClass(pData->otherClass);
^
test.cpp:3:7: note: ‘MyClass& MyClass::operator=(MyClass&&)’ is implicitly deleted because the default definition would be ill-formed:
class MyClass {
^~~~~~~
test.cpp:3:7: error: non-static reference member ‘OtherClass& MyClass::c’, can’t use default assignment operator

有没有解决这个问题的好方法?修补库是一种可能性,但我宁愿不修补。

也许我可以定义自己的new运算符,MyClass将其分配到正确的位置?不过,这似乎并不理想。

您可以使用放置 new 在给定位置创建对象:

new (&pData->myClass) MyClass(pData->otherClass);  

使用正确的构造器:

struct MyAllocatedData
{
MyAllocatedData() : otherClass(), myClass(otherClass) {}
OtherClass otherClass;
MyClass myClass;
};

然后

int main() {
MyAllocatedData data;
// ...
}

或者,如果需要将其放在内存中,请使用"放置新":

MyAllocatedData* pData = new (dataIsSomewhere) MyAllocatedData{};