Magic Enum:C++枚举静态反射库

Magic Enum:C++枚举静态反射库

magic_enumStatic reflection for enums (to string, from string, iteration) for modern C++, work with any enum type without any macro or boilerplate code项目地址:https://gitcode.com/gh_mirrors/ma/magic_enum

1. 项目介绍

Magic Enum是一个C++17及更高版本的头文件库,它提供了对枚举类型的静态反射功能。无需宏或样板代码,你就可以方便地将枚举值转换为字符串,反之亦然。此库支持Clang/LLVM 5以上、MSVC++ 14.11(Visual Studio 2017)及以上、Xcode 10及以上、GCC 9及以上以及MinGW 9及以上编译器。

特性

  • 将枚举值转换为字符串
  • 将字符串转换为枚举值
  • 枚举类型到字符串的迭代
  • 支持流输入/输出操作符
  • 对于位标志型枚举提供位运算操作符
  • 检查类型是否为无范围或有范围的枚举

2. 项目快速启动

安装依赖

在你的包XML中添加<depend>magic_enum</depend>,并将此库添加到工作空间。 在CMakeLists.txt中,执行以下步骤:

find_package(magic_enum CONFIG REQUIRED)
target_link_libraries(your_executable magic_enum::magic_enum)

示例代码

下面展示如何使用magic_enum进行枚举值与字符串之间的转换:

#include <magic_enum.hpp>
#include <iostream>

enum class Color { RED, GREEN, BLUE };

int main() {
    Color color = Color::RED;
    std::cout << magic_enum::enum_name(color) << std::endl;  // 输出 "RED"

    std::string color_name = "GREEN";
    if (auto color_value = magic_enum::enum_cast<Color>(color_name)) {
        std::cout << static_cast<int>(*color_value) << std::endl;  // 输出 "1"
    }
    
    return 0;
}

3. 应用案例和最佳实践

案例1:从命令行读取枚举值

#include <iostream>
#include <magic_enum.hpp>

enum class Direction { LEFT, RIGHT };

int main() {
    std::string input;
    std::getline(std::cin, input);
    auto direction = magic_enum::enum_cast<Direction>(input);
    if (direction.has_value()) {
        std::cout << "Selected direction: " << magic_enum::enum_name(direction.value()) << std::endl;
    } else {
        std::cerr << "Invalid direction!" << std::endl;
    }

    return 0;
}

最佳实践

  • 总是检查enum_cast的结果是否有值,以防止无效的枚举字符串转换。
  • 使用magic_enum::is_unscoped_enum_v<YourEnum>来验证一个类型是否是无范围的枚举。

4. 典型生态项目

  • vcpkg: 可以通过vcpkg工具轻松管理这个库作为外部依赖项。
  • Conan: 在Conan的依赖管理中,可以通过magic_enum/x.y.z添加特定版本。
  • Build2: 在使用Build2构建系统时,可以在manifest文件中添加depends: magic_enum ^x.y.z来指定依赖。

要获取最新更新和详细信息,请访问GitHub项目页面

magic_enumStatic reflection for enums (to string, from string, iteration) for modern C++, work with any enum type without any macro or boilerplate code项目地址:https://gitcode.com/gh_mirrors/ma/magic_enum

  • 20
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

霍虹情Victorious

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值