gpt4 book ai didi

c++ - OpenCV我应该使用智能指针来防止内存泄漏

转载 作者:行者123 更新时间:2023-12-02 10:13:31 25 4
gpt4 key购买 nike

我有一个OpenCV程序,用于预处理和检测OCR的文本区域。
例如,在程序的这一部分中:

    cv::Mat image;
cv::Mat outImage;
cv::Mat image_blurred_5x5_kernel;

cv::resize(image, outImage, cv::Size(), .75, .75);
cv::GaussianBlur(image, image_blurred_3x3_kernel, cv::Size(3, 3), 0);
该程序将创建3张图像;原始,调整大小和模糊的一个。我将只使用我获取的最后一张图像。例如,在调整原始图像的大小并将其存储在某个变量中之后,我将不再使用原始图像。
但是正如您看到的那样,我自己创建和使用了对象,我想知道使用智能指针会导致更好的内存控制吗?还是析构函数足以满足此要求,而两种方法之间的差异可以忽略不计?执行时间是我的首要任务,而不是空间使用。

最佳答案

cv::Mat本身正在管理其资源,该资源将在调用析构函数时释放。由于将它们放在堆栈上,超出范围时将自动处理。
如果您没有将对象放在堆栈上,即应该使用智能指针

cv::Mat* image_ptr = new cv::Mat; // now you need to handle memory, since the allocated object will not be deleted automatically when changing scope
auto image_smart_pointer = std::make_unique<cv::Mat>(); // allocated object will be deallocated correctly when changing scope, since image_smart_pointer is destructed at change of scope.

关于c++ - OpenCV我应该使用智能指针来防止内存泄漏,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62691659/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com