[英]Std::Array with unique_ptr
我有一个类,希望通过传递值数组来实例化。 这里的对象有两个成员,但是为了进行说明已减少了该对象。 将来,我将从磁盘读取值,然后根据这些值创建一个对象,从而创建一个数组。 该对象稍后将具有多个指针,因此为shared_ptr。
首先,我想知道这是否可以防止内存泄漏。 其次,我想知道是否存在较少的实例化对象,然后确定性地销毁它们的方法。
类头文件:
//MyClass.hpp
#pragma once
#include "stdafx.h"
#include <array>
class SimpleClass{
private:
//Per object
double var1;
double var2;
public static:
//For calling when using templates such as std::array<>
//Using __int8 as will not be > 256
static const uint8_t varCount 2;
SimpleBody(std::array<double, varCount> inputArray);
~SimpleBody();
}
类实施
//MyClass.cpp
#pragma once
#include "stdafx.h"
#include <array>
#include "body.hpp"
SimpleBody::SimpleBody(std::array<double, SimpleBody::varCount> inputArray ) {
//Assign var1
MyClass::var1= inputArray[0];
//Assign var2
MyClass::var2= inputArray[1];
};
SimpleBody::~SimpleBody() {
//Add in code here when children need deleting
};
入口点
// EntryPoint.cpp
//
#include "stdafx.h"
#include "MyClass.hpp"
#include <array>
#include <memory>
int main()
{
//Create an array with a smart pointer for memory management
std::unique_ptr< std::array<double, MyClass::varCount> > initArray =
std::make_unique< std::array<double, MyClass::varCount> >();
//Define values
*initArray = { 1.0,2.0 };
//Use array to create object
std::shared_ptr<MyClass> object = std::make_shared<MyClass>(*initArray );
//Free memory
initArray.reset();
object.reset();
return 0;
}
首先,如果您在SimpleBody构造函数中按值传递数组,那么这样做很不好。 更好地使用参考
SimpleBody(const std::array<int, varCount> &inputArray);
目前,您在构造shared_ptr时,unique_ptr会失去数组的所有权。 您无需手动进行重置。 另外,此刻,您的程序到达}行时,内存将被释放。
在您的示例中,您可以跳过唯一指针,因为无论如何您只想要这些值
int main()
{
std::array<double, MyClass::varCount> initArray = { 1.0,2.0 };
std::shared_ptr<MyClass> object = std::make_shared<MyClass>(initArray );
return 0;
}
这样做也一样。
对于“ less肿的”:
总是有auto
:
int main()
{
auto initArray = std::make_unique< std::array<double, MyClass::varCount> >();
*initArray = {1.0,2.0};
auto object = std::make_shared<MyClass>(*initArray );
return 0;
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.