0

0

C++中的std::expected是什么?(如何处理可能的错误返回值)

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-02-10 14:42:09

|

922人浏览过

|

来源于php中文网

原创

std::expected 是 C++23 引入的类型,用于显式表达“成功(含 T)或失败(含 E)”的返回值;而 std::optional 仅表示“有或无值”,不携带错误信息。

c++中的std::expected是什么?(如何处理可能的错误返回值)

std::expected 是什么,和 std::optional 有什么区别

std::expected 是 C++23 引入的类型,用于显式表达「可能成功也可能失败」的返回值。它不是用来替代 std::optional 的——后者只表示「有或没有值」,不携带错误信息;而 std::expected 明确区分:成功时含 T,失败时含 E(比如 std::error_code 或自定义错误枚举)。

常见错误现象:有人试图用 std::optional 表示「计算结果或出错」,但调用方无法知道为什么失败,只能靠额外文档或全局错误码推断。

  • std::expectedE 类型必须是可复制/可移动的,且不能是 void(否则该用 std::optional
  • 不支持隐式转换到 bool,必须显式调用 .has_value() 或用 if (auto res = foo(); res) 这类结构判断
  • 它不接管异常语义:构造失败值不会抛异常,但若 E 构造本身抛异常,则传播出去

怎么从函数返回 std::expected 并正确消费

典型使用场景:系统调用封装、文件读取、JSON 解析等可能失败但又不想用异常的路径。

std::expected safe_divide(int a, int b) {
  if (b == 0) {
    return std::unexpected(std::make_error_code(std::errc::invalid_argument));
  }
  return a / b;
}

消费时别直接解包:

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

  • ❌ 错误写法:int x = *res; —— 若 res 失败会 std::terminate
  • ✅ 推荐写法:用 if (res) 判断再访问 res.value(),或用 res.value_or(42) 提供默认值
  • 更安全的模式是用 and_then 链式处理(C++23 支持),类似 Rust 的 ?
    auto result = parse_json(s).and_then(validate).and_then(save_to_db);

注意:and_then 要求每个函数都返回 std::expected,否则链会断。

HARPA AI
HARPA AI

浏览器插件,ChatGPT自动化助手,将ChatGPT集成到谷歌搜索

下载

std::expected 和异常、错误码、返回结构体比有什么代价

性能上,std::expected 通常比异常轻量(无栈展开开销),但比纯错误码多一次拷贝/移动(尤其 E 较大时)。兼容性方面:仅 C++23 及以上标准可用,GCC 13+、Clang 16+、MSVC 19.35+ 才完整支持。

常见坑:

  • 误以为 std::expected 的内存布局和 union 一样紧凑——实际实现可能带额外标志位,不要做 reinterpret_cast 或 memcpy 操作
  • std::error_code 当作万能错误类型:它不携带上下文字符串,调试困难;建议搭配 std::string 或自定义错误类型(需满足三法则)
  • 忘记 std::expected 不提供 operator== 默认实现,比较两个 expected 需手动展开判断

如何在 C++20 项目里模拟 std::expected 行为

如果不能升级到 C++23,别硬套第三方库(如 tl::expected),容易引入 ABI 或 SFINAE 兼容问题。更稳妥的做法是:

  • 用结构体手动封装:struct Result { bool ok; T value; E error; };,但要自己实现 value()error()has_value() 等接口
  • 或退回到 std::pair<:optional>, std::optional>,虽啰嗦但清晰、无依赖、零成本抽象
  • 真正需要链式处理时,优先考虑重构逻辑:把失败路径提前 return,避免深层嵌套判断

最常被忽略的一点:很多人只关注「怎么返回错误」,却没想清楚「谁负责销毁错误值里的资源」——比如 E 是一个打开的文件句柄,std::expected 不会自动 close,得在 if (!res) 分支里显式清理。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
C++系统编程内存管理_C++系统编程怎么与Rust竞争内存安全
C++系统编程内存管理_C++系统编程怎么与Rust竞争内存安全

C++系统编程中的内存管理是指 对程序运行时内存的申请、使用和释放进行精细控制的机制,涵盖了栈、堆、静态区等不同区域,开发者需要通过new/delete、智能指针或内存池等方式管理动态内存,以避免内存泄漏、野指针等问题,确保程序高效稳定运行。它核心在于开发者对低层内存有完全控制权,带来灵活性,但也伴随高责任,是C++性能优化的关键。

12

2025.12.22

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

435

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

543

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

317

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

79

2025.09.10

string转int
string转int

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

668

2023.08.02

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

803

2023.08.22

scripterror怎么解决
scripterror怎么解决

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

331

2023.10.18

包子漫画网页版入口与全集阅读指南_正版免费漫画快速访问方法
包子漫画网页版入口与全集阅读指南_正版免费漫画快速访问方法

本专题汇总了包子漫画官网和网页版入口,提供最新章节抢先看方法、正版免费阅读指南,以及稳定访问方式,帮助用户快速直达包子漫画页面,无广告畅享全集漫画内容。

40

2026.02.10

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 9.1万人学习

C 教程
C 教程

共75课时 | 4.6万人学习

C++教程
C++教程

共115课时 | 17万人学习

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

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