这篇文章主要介绍“C++17中nodiscard标记符如何使用”,在日常操作中,相信很多人在C++17中nodiscard标记符如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C++17中nodiscard标记符如何使用”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
在C++ 17中引入了一个标记符nodiscard,用于声明一个 “非弃值(no-discard)表达式”。那么在开始之前,我们需要了解一下什么是弃值表达式。
弃值表达式,就是放弃获取返回值的表达式。首先弃值表达式的返回值是非void类型的。一般,我们使用的弃值表达式,其返回值只是起次要的作用,而其本身的作用占主要。比如++i;就是一个弃值表达式,它的主要作用就是累加,但同时我们也可以选择获取其累加的返回值,只不过这是次要的。
再比如,C标准库的文件写入函数,其声明如下:
int __cdecl fputs(const char * __restrict__ _Str,FILE * __restrict__ _File);
它有一个int类型的返回值,用于获取写入状态,它的主要作用是写入文件,我可以选择不获取状态,也可以选择获取状态:
fputs("Hello World",pFile); int result = fputs("Hello World",pFile);
那么我如果想向用户建议获取返回值,这时候,我就可以使用nodiscard标记符。它一般用于标记函数的返回值或者某个类。声明语法为:
/* @since C++17 */ [[nodiscard]] return_type function(); /* @since C++20 */ [[nodiscard("message")]] return_type function(); /* Standard lib defination */ /* #if __cplusplus >= 201703L # define _GLIBCXX_NODISCARD [[__nodiscard__]] #else # define _GLIBCXX_NODISCARD #endif */ _GLIBCXX_NODISCARD return_type function();
如果一个被nodiscard标记了的表达式,如果我们在使用时弃值了,而且没有使用static_cast<void>将其转化为void时,编译器会抛出warning来提醒用户获取返回值。
[[nodiscard]] int func1(){ return 1; } [[nodiscard("nodiscared function")]] int func2(){ return 1; } int main(){ func1(); //warning C++17 func2(); //warning c++20 int a = func1(); //no warning static_cast<void>(func1()); //no warning }
结果如下:
class [[nodiscard]] A{}; enum class [[nodiscard]] B{X,Y}; struct [[nodiscard]] C{}; A createA(){ return A(); } B createB(){ return B::X; } C createC(){ return C(); } int main(){ createA(); createB(); createC(); }
输出如下:
6.cpp: In function 'int main()':
6.cpp:22:12: warning: ignoring returned value of type 'A', declared with attribute 'nodiscard' [-Wunused-result]
22 | createA();
| ~~~~~~~^~
6.cpp:10:3: note: in call to 'A createA()', declared here
10 | A createA(){
| ^~~~~~~
6.cpp:6:21: note: 'A' declared here
6 | class [[nodiscard]] A{};
| ^
6.cpp:23:12: warning: ignoring returned value of type 'B', declared with attribute 'nodiscard' [-Wunused-result]
23 | createB();
| ~~~~~~~^~
6.cpp:14:3: note: in call to 'B createB()', declared here
14 | B createB(){
| ^~~~~~~
6.cpp:7:26: note: 'B' declared here
7 | enum class [[nodiscard]] B{X,Y};
| ^
6.cpp:24:12: warning: ignoring returned value of type 'C', declared with attribute 'nodiscard' [-Wunused-result]
24 | createC();
| ~~~~~~~^~
6.cpp:18:3: note: in call to 'C createC()', declared here
18 | C createC(){
| ^~~~~~~
6.cpp:8:22: note: 'C' declared here
8 | struct [[nodiscard]] C{};
| ^
当返回值为引用或者指针的 类/枚举类/结构(函数不行) 时,nodiscard 就无效了:
class [[nodiscard]] A{}; A& createAref(){ A* a = new A(); return *a; } A* createAptr(){ A* a = new A(); return a; } int main(){ createAref(); //no warning createAptr(); //no warning }
到此,关于“C++17中nodiscard标记符如何使用”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。