在调用类构造函数时初始化std::map
Initializing std::map in a call to a class constructor
我已经看到了我正在尝试的void函数的确切语法,但我无法弄清楚为什么它在我的代码中不工作:
构造函数: class Input
{
public:
Input(const std::map<std::string, void(*)(void)> &arg_0)
{ //...code...// }
};
使用临时std::map:
调用构造函数 Input _Input(
std::map<std::string, void(*)(void)> {
{"exit", [](){exit(1);}}
}
);
同样,只要稍微改变
std::map<std::string, void(*)(void)> NAME = {
{"exit", [](){exit(1);}
}
足以解决问题,并且由于某种原因,NAME也超出了作用域(这正是我想要的)。所以基本上,我知道解决方案,但我想知道为什么第一个代码不起作用。注:错误是
error: expected ‘)’ before ‘{’ token
IN
std::map<std::string, void(*)(void)> {
class BackEnd
{
private:
Input _Input(
std::map<std::string, void(*)(void)> {
{"exit", [](){exit(1);}}
}
);
};
在这种情况下,它停止工作并抛出错误。例如:https://ideone.com/ikGUGF
标题>解决方案是使用新的统一初始化语法代替旧的对象初始化。不知道为什么,也许有人能解释一下。
这听起来像是最令人烦恼的解析问题。
确实在你的代码中:
Input _Input(
std::map<std::string, void(*)(void)> {
// -----------------------------------^
{"exit", [](){exit(1);}}
}
);
Input _Input(...)
可以被解释为函数定义,因此,由于标准,编译器可以这样做。
这个论点被下面的错误强化了:
error: expected ‘)’ before ‘{’ token
这是因为编译器需要一个)
来关闭函数的签名。
对于一个没有人能回答的合理问题,有很多人投了反对票。
我同意你的观点,因为一个不同意的投票应该意味着一个评论,以改善一个问题本身。
无论如何,我希望你能找到有用的答案。
-
解决方案是使用新的统一初始化语法代替旧的对象初始化。不知道为什么,也许有人能解释一下。
-
对于一个没有人能够回答的合法问题,这是很多的反对票。
相关文章:
- 如何导出包含具有"std::unique_ptr"值的"std::map"属性的
- 使用一个考虑到std::map中键值的滚动或换行的键
- 有没有办法对std::unordered_set、std::unrdered_map、std::set、std::map
- 将重物插入std::map
- 使用通用值初始化 std::map,不重复
- 仅包含可移动 std::map 的类的移动构造函数不起作用
- C++:当所有条目都保证是唯一时,替代 std::map
- 使用模板化的键类型定义 std::map,该键类型基于作为参数接收的函数
- 如果 KEY 是 std::list 或 std::vector 而不是值,那么 std::map 的默认行为是什么?
- C++如何创建 std::map
- 从其他容器中移动构造"std::map"
- 将 std::map::emplace 与返回 shared_ptr 的函数一起使用是否正确?
- C++中 std::map 的运行时复杂度是多少?
- 为什么在 std::map 上移动无法将元素从一个映射移动到另一个映射
- 使用重载 [] 运算符返回 std::map() 的可赋值
- std::map, std::unordered_map - 缩小初始值设定项列表中的转换范围
- C++ 使用枚举类对象分配 std::map 值
- 静态 std::map instatiation 在类的方法中调用构造函数吗?
- std::map:当元素不可默认构造时创建/替换元素
- Arduino编译器和STL:使用std::vector和std::map