首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

为什么返回类型为void的函数会是constexpr?

返回类型为void的函数不会被用于表达式的求值,因此它们不会被用于编译时常量表达式的求值。constexpr函数要求其返回类型必须是字面类型,并且函数体必须是一个编译时可求值的常量表达式。因此,返回类型为void的函数无法满足constexpr函数的要求。

constexpr函数是在编译时求值的函数,它可以用于编译时常量的计算和初始化。返回类型为void的函数没有返回值,因此无法用于编译时常量的计算和初始化,也就无法作为constexpr函数使用。

总结起来,返回类型为void的函数不会被用于编译时常量表达式的求值,因此不能被声明为constexpr函数。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

通过OpenFoam记录一些c++的trick(持续更新)

1.template和using的混用: template using vector3 = Vector<T,3> typedef Vector3 Vector3F 2.size_t 当你看到一个对象声明为size_t类型,你马上就知道它代表字节大小或数组索引,而不是错误代码或者是一个普通的算术值 3.static_cast 将类型转化为int 4.类后面加final表示不能继承 5.c++11后的lambda函数: [&](size_t i){ …to do something } 表示传入的是i的地址如果是等于[=],则是传值 6.mutable关键字作用在成员变量前,即使某一个非静态方法后加了const(即不能修改该函数的类里的任何一个变量),也可以修改改变量 7constexpr:constexpr是C++11中新增的关键字,其语义是“常量表达式”,也就是在编译期可求值的表达式。最基础的常量表达式就是字面值或全局变量/函数的地址或sizeof等关键字返回的结果,而其它常量表达式都是由基础表达式通过各种确定的运算得到的。常量表达式主要是允许一些计算发生在编译时,即发生在代码编译而不是运行的时候。这是很大的优化:假如有些事情可以在编译时做,它将只做一次,而不是每次程序运行时。需要计算一个编译时已知的常量,比如特定值的sine或cosin?确实你亦可以使用库函数sin或cos,但那样你必须花费运行时的开销。使用constexpr,你可以创建一个编译时的函数,它将为你计算出你需要的数值。用户的电脑将不需要做这些工作。 constexpr int Inc(int i) { return i + 1; }

02
领券