Constexpr non member 函数和引用 Argos
Constexpr non member function and reference Argos
如果我有一个非成员 constexpr 函数采用引用参数,它必须是常量引用
简短回答:不。
长答案:不,因为 const
运算符只确保非成员函数的数据不会被更改 - 但是,如果您传递参数,此外来参数可能会更改
如果我有一个非成员 constexpr 函数采用引用参数,它必须是常量引用吗?
不,它没有,但它更好。
constexpr
函数的主要用途是在编译时计算表达式。传递对此类函数的非const
引用是没有意义的。如果你选择修改函数中的输入对象,我得问你为什么?如果不修改输入对象,最好使用 const
引用,就像将不修改对象的成员函数设为const
成员函数一样。
以下代码不起作用,因为当函数需要非const
引用时,无法使用临时对象
struct Foo { int i; };
constexpr bar(Foo& f) { return f.i * 2; }
int main()
{
int arr[bar({20})]; // Can't use a temp object
}
以下代码有效。该函数可以与临时对象以及可用作左值的对象一起使用。
struct Foo { int i; };
constexpr bar(Foo const& f) { return f.i * 2; }
int main()
{
int arr[bar({20})];
Foo f{20};
int v = bar(f);
}
相关文章:
- 将对象数组的引用传递给函数
- 什么时候在C++中返回常量引用是个好主意
- 我想将一个对T类型的非常量左值引用绑定到一个T类型的临时值
- 何时在引用或唯一指针上使用移动语义
- 如何在c++中使用引用实现类似python的行为
- 编译C++时未定义的引用
- Ctypes wstring通过引用传递
- c++r值引用应用于函数指针
- 理解c++中的引用
- C++取消引用指针.为什么会发生变化
- 如何修复此错误:未定义对"距离(浮点数,浮点数,浮点数,浮点数,浮点数)"的引用
- 我的项目不会像"undefined reference to `grpc::g_core_codegen_interface'"那样使用未定义的引用错误进行编译
- C++Boost Asio Pool线程,带有lambda函数和传递引用变量
- 强制转换为引用类型
- 引用一个已擦除类型(void*)的指针
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么
- 具有默认值的引用获取函数
- 如何使用基类指针引用派生类成员
- 使用取消引用的指针的多态性会产生意外的结果.为什么?
- Constexpr non member 函数和引用 Argos