c++ - 构造函数和函数中的 CPP 引用

标签 c++ pass-by-reference rvalue-reference lvalue

我对下面的代码有点困惑。 `

class sample
{
     public:
     sample() {  }
     sample( sample& Obj ) {  }
 };

void fun( sample& Obj ) {   }

int main()
{
    sample s(sample());
    fun( sample() );
    return 0;
}

出现以下错误

由于以下错误,编译失败。 main.cpp:在函数“int main()”中: main.cpp:29:19: 错误:从类型为“sample”的右值中对类型为“sample&”的非常量引用进行无效初始化 fun(sample() );

我知道将 fun 中的参数从 sample& obj 更改为 const sample &obj 将解决错误。

我的问题是,即使对于复制构造函数,也已发送一个临时对象。但是为什么编译器没有抛出同样的错误。

欢迎详细解释

问候 Prasath S.

最佳答案

这一行:

sample s(sample());

是一个名为 s 的函数的声明,它返回一个样本对象,并将一个不带参数的函数作为参数并返回一个样本对象。您根本没有调用复制构造函数。它被称为“最令人烦恼的解析”。虽然有些人反对这个名字。

你可以通过写入控制台或者在复制构造函数中放置一个断点来看到这种情况,它永远不会被调用。您将看到的另一件事是向您的类添加一个变量成员并尝试访问它是行不通的。行后:

sample s(sample());

尝试使用:

s.sampleMember = 1;

而且会编译失败,理由是s是函数声明,不是对象。有几种方法可以避免这种情况,您可以将参数括在另一组括号中:

sample s((sample()));

或者您可以使用 C++11 以后的样式大括号初始化,例如:

sample s(sample{});

关于c++ - 构造函数和函数中的 CPP 引用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48942710/

相关文章:

c# - 我可以有一个接口(interface)参数,通过引用传递吗?

将 void 指针转换为指向 A 类型指针的指针以及取消引用与将 void 指针转换为 A 类型 : Why?

c++ - 接收器参数和异常

c++ - 重载 operator+ 时的区别

c++ - WINAPI - 在不成为所有者的情况下关闭互斥锁

初始化后具有固定容量的 C++ vector

c++ - 获取对 unordered_map operator[] 返回值的引用

c++ - 为什么我在传递 vl 或 vl1 时得到与输出相同的值 (0x7fff5fbff808)?地址应该不同

c++ - pass-by-value-and-then-move 结构是一个坏习惯吗?

c++ - 当我们使用右值引用时到底发生了什么,std::move 是如何工作的?