是否可以更改此C ++ 11初始化:
const std::map<int, std::map<int, std::string>> test =
{{1,
{{1, "bla"},
{2, "blie"}
}
},
{3,
{{1, "ha"},
{2, "hie"}
}
}
};
使用Boost.Assignment某种形式而不使用临时工具?不幸的是,似乎不可能以这种方式嵌套map_list_of
。我错了吗?
注意:我准备好了一些可怕的宏。只要它能够正常工作就可以了。可变参数模板不正常,因为目标编译器是Intel C ++ 2013和/或MSVS2012。
编辑:我想使用的“理想”包装器界面如下所示:
//header
extern const std::map<int, std::map<int, std::string>> test;
// source file
/*something*/ test
/*something*/ 1,
/*something*/ 1, "bla" /*something*/
/*something*/ 2, "blie" /*something*/
/*something*/ 2 //etc...
任何/*something*/
都可以为空。这应该使用C ++ 11大括号init或boost::assign::map_list_of
。我试图避免手动重复,如:https://stackoverflow.com/a/1872506/256138
答案 0 :(得分:4)
可以以这种方式嵌套map_list_of
,with hackery(但可能是在下面创建的临时工具,我不确定):
#include <map>
#include <string>
#include <boost/assign/list_of.hpp>
using boost::assign::map_list_of;
const std::map<int, std::map<int, std::string> > test =
map_list_of
(1, map_list_of
(1, "bla")
(2, "blie")
.convert_to_container<std::map<int, std::string> >()
)
(3, map_list_of
(1, "ha")
(2, "hie")
.convert_to_container<std::map<int, std::string> >()
)
;
// Correctly prints "hie".
//std::cout << test.find(3)->second.find(2)->second << "\n";
可能的宏界面(忽略空要求,主要是因为我不确定它是什么意思):
#include <iostream>
#include <string>
#include <map>
#ifdef CPP_11_AVAILABLE // Unsure what the actual macro is.
#define map_entries_begin {
#define map_entries_end }
#define map_entry_begin {
#define map_entry_end },
#else
#include <boost/assign/list_of.hpp>
#define map_entries_begin boost::assign::map_list_of
#define map_entries_end
#define map_entry_begin (
#define map_entry_end )
#endif
const std::map<int, std::map<int, std::string>> test =
map_entries_begin
//------//
map_entry_begin
1, map_entries_begin
map_entry_begin 1, "bla" map_entry_end
map_entry_begin 2, "blie" map_entry_end
map_entries_end
map_entry_end
//------//
map_entry_begin
3, map_entries_begin
map_entry_begin 1, "ha" map_entry_end
map_entry_begin 2, "hie" map_entry_end
map_entries_end
map_entry_end
map_entries_end;
int main()
{
std::cout << test.find(3)->second.find(2)->second << "\n";
return 0;
}
诚然相当冗长,但似乎符合你的要求。
请参阅http://ideone.com/6Xx2t上的C ++ 11在线演示。