我将向您展示如何具体解决您的问题,以及如何解决一般问题。
一般来说,就像任何太复杂的问题一样,试着把它分解。在 C 和 C++ 中分解复杂类型声明的工具长期以来一直是“typedef”。以下是您对级联类型定义的处理方法,如您所拥有的:采用最内层的包装类型,即包装您的类的 unique_ptr,并为您想要包装的类型创建一个 typedef。然后,继续对该类型包装的类型执行相同的操作,直到您处于最外层的类型。
这仅与您的问题相关,但我想提一下,因为您可能会遇到类似的问题,例如您现在使用模板时遇到的问题。由于 C++11,您还可以更方便地使用“using”子句为涉及模板参数的类型定义别名:http: //en.cppreference.com/w/cpp/language/type_alias。如果您在这种情况下感兴趣或将来变得相关,请查看该链接!
针对您的具体问题。函数“test_dynamic_2darray1”构建了一个二维 10x10 智能指针数组。当您运行此代码时,您应该看到析构函数的 100 行输出,就在托管数组超出范围时。
size_t destructor_count = 0;
class MyClass {
public:
~MyClass() {
std::cout << "Destructor call #" << ++destructor_count << std::endl;
}
};
typedef std::unique_ptr<MyClass[]> ManagedC;
void test_dynamic_2darray1() {
size_t dimension1 = 10, dimension2 = 10;
auto managed_array = std::unique_ptr<ManagedC[]>(new ManagedC[dimension1]);
for (size_t i = 0; i < dimension1; ++i)
managed_array[i] = ManagedC(new MyClass[dimension2]);
}
将其与此代码进行比较,其中不会调用动态分配的类实例的析构函数,并且您看不到任何输出:
void test_dynamic_2darray2() {
size_t dimension1 = 10, dimension2 = 10;
auto simple_array = new MyClass*[dimension1];
for (size_t i = 0; i < dimension1; ++i)
simple_array[i] = new MyClass[dimension2];
}
我希望我能够回答你的问题!:) 如果你想让我详细说明一些事情,请告诉我!前几天我还写了一篇您可能感兴趣的相关博文:http: //frankriesecodingblog.blogspot.com/2015/01/performance-of-dynamic-multi.html。我在这里发布它,因为它展示了多维动态数组的不同方法,并研究了使用向量向量的常用方法的性能。
最后但同样重要的是,让我提一下您使用 int 来迭代数组。我希望这不会变成我的烦恼,但我看到这已经做了很多。您可能应该使用 size_t。为什么?例如,在我的 64 位机器上,“int”是 32 位的,但由 size_t 表示的地址是 64 位的。这种对 int 的误用是许多错误的原因,尤其是在将 32 位应用程序移植到 64 位机器时。如果您需要有符号类型,例如数组地址之间的偏移量,更好的用途可能是 ptrdiff_t。