我有一个带有构造函数和析构函数的类,以及下面两个代码:
class propagation_module{
private:
gsl_interp_accel *xa;
interp2d_spline *interp_s;
public:
propagation_module()
{
std::vector<int> p_N = {1, 2, 3}, z_vec = {1, 2, 3};
xa = gsl_interp_accel_alloc();
interp_s = interp2d_spline_alloc(interp2d_bicubic, p_N.size(), z_vec.size());
}
~propagation_module(){
gsl_interp_accel_free(xa);
interp2d_spline_free(interp_s);
}
}
我想用std :: unique_ptr-variables替换指针,但是我不明白如何实现自由功能。根据其他一些问题,以下方法应该起作用:
class propagation_module
{
private:
std::unique_ptr<gls_interp_accel, decltype(&gsl_interp_accel_free)> xa;
std::unique_ptr<interp2d_spline, decltype(&interp2d_spline_free)> interp_s;
public:
propagation_module()
{
//Same as above
}
//No destructor necessary
}
是正确的,还是我忘记了什么?
你在那儿 默认情况下,std::unique_ptr
在unique_ptr
创建时未传递任何删除器时,它将默认构造其删除器。您为删除器提供了正确的类型,但也需要提供它们的值:
public:
propagation_module()
{
std::vector<int> p_N = {1, 2, 3}, z_vec = {1, 2, 3};
xa = {gsl_interp_accel_alloc(), &gsl_interp_accel_free};
interp_s = {interp2d_spline_alloc(interp2d_bicubic, p_N.size(), z_vec.size()), &interp2d_spline_free};
}
另外,如果您不想每次创建唯一指针时都必须提供正确的删除器,则可以创建默认可构造的包装器来调用正确的函数:
struct GslInterpAccelFree
{
void operator() (gsl_interp_accel *p) const { gsl_interp_accel_free(p); }
};
struct Interp2dSplineFree
{
void operator() (interp2d_spline *p) const { interp2d_spline_free(p); }
};
class propagation_module
{
private:
std::unique_ptr<gls_interp_accel, GslInterpAccelFree> xa;
std::unique_ptr<interp2d_spline, Interp2dSplineFree> interp_s;
public:
propagation_module()
{
std::vector<int> p_N = {1, 2, 3}, z_vec = {1, 2, 3};
xa.reset(gsl_interp_accel_alloc());
interp_s.reset(interp2d_spline_alloc(interp2d_bicubic, p_N.size(), z_vec.size()));
}
//No destructor necessary
}
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句