c++11?實現(xiàn)枚舉值到枚舉名的轉換問題
效果
ENUM_DEFINE ( Color,
Red,
Blue,
)
EnumHelper(Color::Red) -> "Red"
EnumHelper(Color::Red, std::toupper) -> "RED"關鍵技術
__VA_ARGS__
__VA_ARGS__ 實現(xiàn)了可變參數(shù)的宏。
#define XXX(type, ...) enum class type { __VA_ARGS__ };XXX(Color, Red, Blue) 等價于:
enum class Color
{
Red,
Blue
};#__VA_ARGS__
#__VA_ARGS__ 可將宏的可變參數(shù)轉為字符串。
#define XXX(type, ...) #__VA_ARGS__
XXX(Color, Red, Blue) 等價于:"Red, Blue"
在函數(shù)外執(zhí)行代碼的能力
在函數(shù)體外,可以通過定義全局變量來執(zhí)行一個函數(shù)。需要注意的是,頭文件中正常是不能進行變量初始化的,除非加上 static 或者 const。
const int temp = initialize();
另外,如果多個代碼文件 #include 了該頭文件,會產生多個變量,即在不同代碼文件取得的 temp 變量不是同一個。與之對應,initialize 函數(shù)也會調用多次。
模板函數(shù)的靜態(tài)變量
函數(shù)的靜態(tài)變量可以用于存放枚舉值到枚舉字符串的映射,而將枚舉類型作為模板參數(shù)的模板函數(shù),則可以直接為每種枚舉提供了一個映射容器。
關鍵代碼
template<typename T>
string EnumHelper(T key, const std::function<char(char)> processor = nullptr, const char* pszName = NULL)
{
static_assert(std::is_enum_v<T>, __FUNCTION__ "'s key need a enum");
static map<T, string> s_mapName;
if (nullptr != pszName)
{
s_mapName[key] = pszName;
}
std::string res = "";
auto it = s_mapName.find(key);
if (it != s_mapName.end())
res = it->second;
if (nullptr != processor)
std::transform(res.begin(), res.end(), res.begin(), processor);
return res;
}
template <class T>
size_t analystEnum(T enumClass, const char* pszNames)
static_assert(std::is_enum_v<T>, __FUNCTION__ "'s enumClass need a enum");
cout << "analystEnum: " << pszNames << endl;
if (nullptr != pszNames)
const vector<string>& vecName = split(pszNames, ",");
for (int i = 0; i < vecName.size(); ++i)
{
if (vecName.at(i).size() > 0)
{
EnumHelper((T)(i + 1), nullptr, vecName.at(i).c_str() + (i == 0 ? 0 : 1) );
}
}
return rand();
return rand();
#define ENUM_DEFINE(type, ...) enum class type { placeholder, __VA_ARGS__ }; static const size_t g_uEnumSizeOf##type = analystEnum(type::placeholder, #__VA_ARGS__);到此這篇關于c++11 實現(xiàn)枚舉值到枚舉名的轉換的文章就介紹到這了,更多相關c++11 枚舉值到枚舉名的轉換內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
c++利用stl set_difference對車輛進出區(qū)域進行判定
這篇文章主要介紹了set_difference,用于求兩個集合的差集,結果集合中包含所有屬于第一個集合但不屬于第二個集合的元素,需要的朋友可以參考下2017-03-03
C++實現(xiàn)LeetCode(83.移除有序鏈表中的重復項)
這篇文章主要介紹了C++實現(xiàn)LeetCode(83.移除有序鏈表中的重復項),本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下2021-07-07

