我正在编写一些OpenCV代码,将队列中的任何cv::Mat
(s)写入文件。不幸的是,对cv::imread
的调用似乎导致了内存泄漏。当这些行被注释掉时,不会发生内存泄漏。
void ck::file_pipe_handler() {
std::vector<int> compression_params;
compression_params.push_back(CV_IMWRITE_PNG_COMPRESSION);
compression_params.push_back(0);
while (true) {
std::unique_lock<std::mutex> pop_lock(
file_pipe_mutex, std::defer_lock);
if (file_pipe.empty()) {
usleep(10);
continue;
}
pop_lock.lock();
frame_details frame_deets = file_pipe.front();
file_pipe.pop();
pop_lock.unlock();
auto base_dir = output_file_name + "/" + frame_deets.serial_number;
auto rgb_reg_dir = base_dir + "/rgb_registered/";
auto rgb_raw_dir = base_dir + "/rgb_raw/";
auto depth_dir = base_dir + "/depth/";
// If you comment out the imwrite calls here,
// the memory leak does not occur
if (register_rgb)
cv::imwrite(rgb_reg_dir + std::to_string(frame_deets.timestamp_rgb)
+ ".png", frame_deets.frame_registered.first);
cv::imwrite(rgb_raw_dir + std::to_string(frame_deets.timestamp_rgb)
+ ".png", frame_deets.raw_rgb);
cv::imwrite(depth_dir + std::to_string(frame_deets.timestamp_depth)
+ ".png", frame_deets.frame_registered.second, compression_params);
frame_deets.raw_rgb.release();
frame_deets.frame_registered.first.release();
frame_deets.frame_registered.second.release();
}
}
我将释放调用添加到最后,以确保正确释放cv::Mat
(s)。此外,我确定队列没有填满。我正在使用OpenCV 3.1。
答案 0 :(得分:0)
并发问题 - 只需在cv :: imwrite调用后移动解锁。