繁体   English   中英

类型const GCC的标量初始化器周围的大括号

[英]braces around scalar initializer for type const GCC

typedef std::map<int, const char*> error_code_tbl_t;
typedef error_code_tbl_t::value_type error_code_entry_t;
const error_code_entry_t error_code_tbl_[] = {
    { ERR_OK              , "ERR_OK" },
    { ERR_RT_OUT_OF_MEMORY, "ERR_RT_OUT_OF_MEMORY" }, 
    // ...
};
const error_code_tbl_t error_code_tbl( begin(error_code_tbl_)
                                     , end  (error_code_tbl_) );

const char* err2msg(int code)
{
    const error_code_tbl_t::const_iterator it = error_code_tbl.find(code);
    if(it == error_code_tbl.end())
      return "unknown";
    return it->second;
}

上面显示的代码抛出“错误:在标量初始值设定项周围为类型输入错误_code_code_entry_t”。任何人都可以帮我修复它吗?

在C ++ 11中,这很好,尽管你可以通过直接初始化地图而不是使用数组来简化它。

如果您遇到过去,那么您无法从支撑的初始化列表中初始化value_typestd::pair的别名); 虽然有些编译器可能允许将其作为非标准扩展。 相反,你需要:

const error_code_entry_t error_code_tbl_[] = {
    // Either like this
    error_code_entry_t(ERR_OK, "ERR_OK"),

    // Or like this
    std::make_pair(ERR_RT_OUT_OF_MEMORY, "ERR_RT_OUT_OF_MEMORY"),

    // ...
};

你似乎有一个C ++ 03编译器,因为它应该在C ++ 11中编译。 由于error_code_entry_t是map的value_type ,它实际上是std::pair<const in, const char*> (是的,键类型的const是正确的)。 这不是聚合,所以你不能像那样初始化它。 要修复手头的错误,您可以尝试以下方法:

const error_code_entry_t error_code_tbl_[] = {
    error_code_entry_t( ERR_OK              , "ERR_OK" ),
    error_code_entry_t( ERR_RT_OUT_OF_MEMORY, "ERR_RT_OUT_OF_MEMORY" ), 
    // ...
};

但是既然你想将它们放入地图中,我会考虑使用boost.assign:

#include <boost/assign/list_of.hpp>

const error_code_tbl_t error_code_tbl = boost::assign::map_list_of
  (ERR_OK              , "ERR_OK")
  (ERR_RT_OUT_OF_MEMORY, "ERR_RT_OUT_OF_MEMORY")
;

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM