c++ - map 中c++ map 的简写语法

标签 c++ map

如果我有如下定义:

typedef map<string, Foo> Foo_map_1
typedef map<string, Foo_map_1> Foo_map_2
typedef map<string, Foo_map_2> Foo_map_3
typedef map<string, Foo_map_3> Foo_map_4
typedef map<string, Foo_map_4> Foo_map_5

无论如何我可以概括一下,例如,我可以这样做,

Foo_map<10>

并有一个 10 倍的嵌套 map 。我不需要像 boost::recursive_wrapper 这样的东西,因为级别的数量总是不变的。

最佳答案

即使对于有限的 C++ 元编程能力,这似乎也很容易:

#include <map>
#include <string>

template<int N, typename K, typename V>
struct NMap { typedef std::map<K, typename NMap<N-1, K, V>::type> type; };

template<typename K, typename V>
struct NMap<1, K, V> { typedef std::map<K, V> type; };

int main(int argc, const char *argv[]) {
    NMap<3, int, std::string>::type m;
    m[1][2][3] = "Test";
    return 0;
}

关于c++ - map 中c++ map 的简写语法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23601686/

相关文章:

c++ - 使用 std::vector 作为 std::map 的键在未找到和使用 reserve() 时不返回 end()

javascript - 带下划线的 map 缩小对象

c++ - 如何通过 << 运算符将参数传递给函数?

c++ - std::sort 没有仿函数

c++ - 如何在 C++ 中使 .Exe 复制自身?

c++ - 如何在 C++ 中初始化私有(private)静态常量映射?

performance - 游戏 map 网格对网络浏览器的负担有多大?

c++ - boost 从结构列表派生的结构的序列化

c++ - 使用 VS2012/VTune 进行缓存分析

java.io.NotSerializableException : java. util.HashMap$值