从 std::map 中删除 std::function lambda 包装方法

Removing std::function lambda-wrapped method from std::map

我正在使用 std::functionstd::map 创建一个回调系统。该地图使用 int 作为键,值为 std::function。我将方法绑定到这些函数中。我想知道如果我调用 map.erase(i),会从内存中删除 std::function,还是会发生内存泄漏?

这是一些示例代码:

#include <iostream>
#include <functional>
#include <map>

using namespace std;

class TestClass{
    public: 
        TestClass(int _i, map<int, function<void()>>& test_map):i(_i){
            test_map[i]=[&](){this->lambda_test();};
        };
        void lambda_test(){cout << "output" << " " << i<< endl;};
    private:
        int i;
};

int main() {
    map<int, function<void()>> test_map;
    TestClass* test = new TestClass(1, test_map);
    test_map[1]();
    delete test;
    test_map.erase(1); // <-- here
  };                   

最后一个 test_map.erase(1); 是否从内存中删除了 std::function

这里有关于实际内存分配方面的 lambda 的很好解释:

据我了解,lambda 语法创建一个 r 值,将其复制(连同任何捕获的状态等)到 std::function。这将被 std::function 的析构函数删除,当您调用擦除时 std::map 的析构函数调用(and/or 当映射超出范围时)。

虽然这不是好的代码,但没有内存泄漏;您正在按值(而不是指针)将 std::function 存储在 std::map 中,因此 std::map::erase 将调用 std::function.

的析构函数

换句话说,您没有 new 任何 std::function,因此您不需要 delete 任何 std::function.