key->value Table方式取值的一种方法 (使用lambda表达式)

// 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;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值