ecCodes(grib 阅读库)不释放内存

ecCodes (grib reading library) does not free the memory

我在我的项目中使用 ecCodes library,我遇到了一个问题,即在读取文件之间没有释放内存。

代表问题的最小示例是这个(并且基本上是这两个库 API 用法示例的组合 [1](https://confluence.ecmwf.int/display/ECC/grib_get_keys) [2]:

#include <string>
#include <vector>
#include <iostream>
#include "eccodes.h"

int main() {

    std::string filenames[] = {"../data/era5_model.grib", "../data/era5_model2.grib", "../data/era5_model3.grib",
                               "../data/era5_model4.grib"};

    std::vector<long> vec = {};

    for (auto & filename : filenames) {
        FILE* f = fopen(filename.c_str(), "r");
        int err = 0;
        codes_handle* h;

        while ((h = codes_handle_new_from_file(nullptr, f, PRODUCT_GRIB, &err)) != nullptr) {
            long k1 = 0;
            err = codes_get_long(h, "level", &k1);
            vec.push_back(k1);
        }

        codes_handle_delete(h);
        fclose(f);
    }

    std::cout << vec[52];

    return 0;
}

在示例中,程序读取 4 个相同的 ERA5 文件,每个文件大小为 1.5GB。在打开新文件之前,使用 codes_handle_delete() 和 fclose() 关闭前一个文件。 因此,预期的行为是内存使用量保持在 1.5GB 左右。然而,实际上内存使用量稳步增加到大约 6.5GB,并在程序关闭时被释放(见下面的截图)。

此特定示例已在 CLion 上使用 CMake(发布配置)运行,但所有其他配置以及我使用 FFI 调用 ecCodes 的其他 Rust 项目都会出现此问题。

该库似乎经过了良好的测试和支持,因此它似乎不太可能是库错误。因此,这是预期的行为还是我的代码错误?如果是后者,我该如何纠正?

我正在使用 Ubuntu 21.04 和 ecCodes 2.20.0 安装了 apt

所以我联系了图书馆的作者,发现我没有仔细阅读this example

为了正确释放内存的 ecCodes codes_handle 每次创建时都应该删除它(类似于每次分配内存时应该如何释放内存)。因此在我的示例中 codes_handle_delete() 应该在 while 循环中:

while ((h = codes_handle_new_from_file(nullptr, f, PRODUCT_GRIB, &err)) != nullptr) {
    long k1 = 0;
    err = codes_get_long(h, "level", &k1);
    vec.push_back(k1);
    codes_handle_delete(h);
}   

在那之后内存使用量的变化几乎不明显。