簡體   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