// name2id.h
#ifndef _NAME2ID_H_
#define _NAME2ID_H_
struct name2id
{
const char* name;
int id;
};
int GetIDByName(const char* name);
#endif // _NAME2ID_H_
// name2id.cpp
#include "name2id.h"
#include "algorithm"
struct name2id name2idTable[] =
{
{"test03", 3},
{"test01", 1},
{"test02", 2},
};
static bool SortName2ID(name2id* begin, name2id* end)
{
std::sort(begin, end, [](name2id lhs, name2id rhs)->bool{return strcmp(lhs.name, rhs.name) < 0;});
return true;
}
// name2idTable没法在.h声明,sort操作要求程序启动做,这是一种方法
// 这里程序启动的时候会赋值,就会调用sort
static bool gbName2ID = SortName2ID(name2idTable, name2idTable + sizeof(name2idTable) / sizeof(name2idTable[0]));
int GetIDByName(const char* name)
{
auto xxx = std::lower_bound = (name2idTable, name2idTable + sizeof(name2idTable) / sizeof(name2idTable[0]), name,
[](name2id lhs, const char* rhs)->bool{return strcmp(lhs.name, rhs) < 0});
if (xxx != name2idTable + sizeof(name2idTable) / sizeof(name2idTable[0]))
return xxx->id;
return -1;
}
key->value Table方式取值的一种方法 (使用lambda表达式)
最新推荐文章于 2021-02-17 02:44:42 发布