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

本文介绍了一种在C++中实现名称到ID映射的方法,通过使用全局静态变量初始化时对结构体数组进行排序,实现了快速查找功能。这种方法适用于需要将字符串名称映射为整型ID的应用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值