0

0

c++ [[nodiscard]]有什么用 c++防止函数返回值被忽略【技巧】

冰火之心

冰火之心

发布时间:2026-01-04 19:41:53

|

843人浏览过

|

来源于php中文网

原创

[[nodiscard]]是C++17引入的属性,用于标记返回值不应被忽略的函数,如返回状态、资源或关键标志的函数;忽略时编译器警告,配合-Werror=nodiscard等选项可升级为错误。

c++ [[nodiscard]]有什么用 c++防止函数返回值被忽略【技巧】

[[nodiscard]] 是 C++17 引入的属性,用来告诉编译器:这个函数的返回值**不应该被忽略**。如果调用者没用它的返回值,编译器就会发出警告(甚至报错,取决于编译选项)。

什么时候该加 [[nodiscard]]?

适用于那些**返回重要信息、状态或资源**,而忽略它可能导致逻辑错误、资源泄漏或未定义行为的函数:

  • 返回错误码或状态(如 std::expectedstd::optional、自定义结果类型)
  • 返回新分配的资源(如智能指针工厂函数、临时对象构造器)
  • 返回需要显式检查的标志(如 std::regex_match 的返回值)
  • 返回不可复制/移动的对象,其语义依赖于使用(比如某些 RAII 包装器)

怎么用?写法很简单

直接加在函数声明前或后(推荐放在前面,更清晰):

// 示例:一个可能失败的解析函数

[[nodiscard]] std::optional parse_int(const std::string& s);

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

Faceswap
Faceswap

免费开源的AI换脸工具

下载
// 调用时若忽略返回值,GCC/Clang/MSVC 都会警告

parse_int("123"); // ⚠️ 警告:nodiscard 函数的返回值被忽略

配合编译器选项效果更好

单独加 [[nodiscard]] 只触发警告。想强制要求处理,可配合:

  • GCC/Clang:-Werror=nodiscard 把警告升级为错误
  • MSVC:/wd4834 控制,或用 /WX 启用所有警告为错误

这样能确保 CI 或团队开发中没人绕过检查。

注意几个常见坑

  • 不是所有返回值都适合加——比如 int size() const 这种只读接口,忽略它通常无害,加了反而干扰开发体验
  • 类成员函数也可以加:[[nodiscard]] std::string_view get_name() const;
  • C++20 起支持对枚举和类加 [[nodiscard]],表示“创建该类型对象不应被忽略”(例如防止忘记赋值给变量)
  • 如果确实要忽略,可用 (void)func();[[maybe_unused]] auto x = func(); 显式压制

相关专题

更多
string转int
string转int

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

314

2023.08.02

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

520

2023.09.20

string转int
string转int

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

314

2023.08.02

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

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

526

2024.08.29

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

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

49

2025.08.29

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

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

191

2025.08.29

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

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

174

2023.11.23

java中void的含义
java中void的含义

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

94

2025.11.27

AO3中文版地址汇总
AO3中文版地址汇总

本专题整合了AO3中文版地址合集,阅读专题下面的文章了解更多详细内容。

0

2026.01.06

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

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

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