传递引用需要具有初始值
Pass by reference need to have initial value?
本文关键字:引用 更新时间:2023-10-16
当函数的参数通过引用传递时,该参数是否必须具有初始值?我写了一个小函数,通过引用接收uin64_t,但当我执行uint64_t a; func(VAL, a);\ VAL is definitely defined
时,它崩溃了
该函数只是给a
一个新值,因此未定义的值
这取决于函数的作用。如果它试图读取参数中的值,则会得到未定义的行为。如果你只是分配给参数,你就可以了:
void func(int & var) {
var = 5; // fine
}
void func(int & var) {
std::cout << var << std::endl; // not fine
}
与引用无关-使用统一变量通常会导致未定义或至少不必要的行为。然而,像这样的东西是可以的:
void f( int & x ) {
x = 42;
}
int main() {
int a;
f( a );
}
读取未初始化的变量会调用未定义的行为。
问题的答案是否定的。应用程序崩溃的原因可能是a没有初始化。这就是为什么总是初始化变量很重要。
相关文章:
- 将对象数组的引用传递给函数
- 什么时候在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*)的指针
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么
- 具有默认值的引用获取函数
- 如何使用基类指针引用派生类成员
- 使用取消引用的指针的多态性会产生意外的结果.为什么?
- 如何引用基类的派生类?