0

0

C++中std::to_underlying怎么快速转换枚举_C++23强类型枚举操作【技巧】

冰火之心

冰火之心

发布时间:2026-02-04 14:41:01

|

533人浏览过

|

来源于php中文网

原创

std::to_underlying是C++23引入的专用函数,用于安全、精确地将enum class转换为其底层类型值,要求编译器支持C++23、枚举为作用域枚举且值为常量表达式。

c++中std::to_underlying怎么快速转换枚举_c++23强类型枚举操作【技巧】

std::to_underlying 是 C++23 引入的专用工具,专为将 enum class(强类型枚举)安全转为其底层整型值而设计。它比手动 static_cast 更清晰、更类型安全,且编译期可检查——但前提是你的编译器已支持 C++23 且启用了对应标准。

为什么不能直接用 static_cast

虽然 static_cast(MyEnum::Value) 在绝大多数情况下能工作,但它绕过了类型系统约束,容易误用于非枚举类型,也缺乏语义表达力。更重要的是:当枚举底层类型不是 int(比如 enum class E : uint8_t),static_cast 可能引发隐式截断或符号扩展,而 std::to_underlying 返回的是**精确的底层类型**,不做强制重解释。

  • 它返回的是枚举定义时指定的底层类型(如 uint16_t),不是硬编码int
  • 对非枚举类型调用会触发编译错误,而不是静默转换
  • 在 constexpr 上下文中完全可用,适合元编程和模板推导

怎么用?必须满足哪些条件?

使用前需确认三点:

  • 编译器支持 C++23(GCC 13+、Clang 16+、MSVC 19.35+;并启用 -std=c++23 或等效选项)
  • 目标枚举必须是 enum classenum struct(即作用域枚举),普通 enum 不允许调用
  • 枚举值必须是常量表达式(即编译期可知),否则无法用于 constexpr 场景

基本用法:

enum class Color : uint8_t { Red = 1, Green = 2, Blue = 4 };
constexpr auto val = std::to_underlying(Color::Red); // 类型是 uint8_t,值是 1

立即学习C++免费学习笔记(深入)”;

常见误用与编译错误

以下写法都会导致编译失败:

HyperWrite
HyperWrite

AI写作助手帮助你创作内容更自信

下载
  • 对非作用域枚举调用:enum OldStyle { A }; std::to_underlying(A); → 错误:not an enumeration type
  • 传入非常量表达式(如函数参数):void f(Color c) { auto x = std::to_underlying(c); } → 非 constexpr 上下文虽可能通过,但失去类型推导优势;若在 constexpr 函数中则报错
  • 忘记包含头文件: —— C++23 中该函数定义在此头文件,不是

典型错误信息:error: no matching function for call to 'to_underlying',往往是因为类型不匹配或标准未启用。

替代方案:C++20 及更早版本怎么办?

如果无法升级到 C++23,推荐封装一个轻量兼容函数:

template 
constexpr std::underlying_type_t to_underlying(E e) noexcept {
return static_cast>(e);
}

这个实现复用了 std::underlying_type_t 确保类型精准,并保留 constexpr 属性。注意它仍要求 E 是枚举类型,否则 std::underlying_type_t 会 SFINAE 失败。

真正容易被忽略的是:即使你写了这个替代函数,也无法获得 C++23 版本的“编译期类型检查强化”——例如传入一个 int 假冒枚举值,它仍会静默转换成功。而原生 std::to_underlying 会直接拒绝。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1506

2023.10.24

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

288

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

306

2023.10.25

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

564

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

547

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

153

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

204

2025.08.29

javascriptvoid(o)怎么解决
javascriptvoid(o)怎么解决

javascriptvoid(o)的解决办法:1、检查语法错误;2、确保正确的执行环境;3、检查其他代码的冲突;4、使用事件委托;5、使用其他绑定方式;6、检查外部资源等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

177

2023.11.23

抖音网页版入口与视频观看指南 抖音官网视频在线访问
抖音网页版入口与视频观看指南 抖音官网视频在线访问

本专题汇总了抖音网页版的入口链接、官方登录页面以及视频观看入口,帮助用户快速访问抖音网页版,提供免登录访问方式和直接进入视频播放页面的方法,确保顺利浏览和观看抖音视频。

19

2026.02.04

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.4万人学习

Rust 教程
Rust 教程

共28课时 | 5.4万人学习

Git 教程
Git 教程

共21课时 | 3.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号