通过引用传递'on the fly'创建的对象

Passing by reference of objects created 'on the fly'

本文关键字:fly 创建 对象 the on 引用      更新时间:2023-10-16

如果这个问题已经有了答案,我很抱歉——我已经搜索过了,但是这是一个很难找到的搜索词,因为通过参考传递的问题太多了。

我遇到的问题是,当我编译这类东西时,我得到了一个4级警告:

class MyClass
{
public:
    MyClass() {};
};
void DoSomethingToMyClass(MyClass& my_class_reference);

void MyRoutine()
{
    DoSomethingToMyClass(MyClass());
};

警告(C4239)基本上说有一个从实例到引用的不可靠的强制转换。我从仔细的检查中学会了不要注销4级警告,因为它们中的许多已经确定了我(和其他人)代码中的错误,例如将-1返回为size_t(知道size_t(-1)实际上是什么加分)。

谁能给我解释一下上面的代码到底是做什么的?我最偏执的理论是:

  • MyClass()的一个实例被即时创建,但是没有给出一个正确的句柄。
  • 在my_class_reference引用上执行的操作会触发错误。

另一个极端是C4239总是可以被忽略…

*[类似的情况是某人默认引用:

void DoSomethingToMyClass(MyClass& my_class_reference=MyClass());

这将生成相同的警告,但部分内容将在另一个主题中介绍。编辑:

谢谢你们的快速回应,伙计们。对不起:应该说一下Visual Studio中的vc++

您会得到警告,因为这不是标准的c++,而是允许您将临时绑定到非const引用的MS扩展。

就是不。使用const引用参数:

void DoSomethingToMyClass(const MyClass& my_class_reference);

可能不适用于这里,正如其名称所暗示的那样,该方法会改变类,或者事先创建对象:

MyClass x;
DoSomethingToMyClass(x);

您正在通过MyClass()创建一个临时的无名对象,并且根据c++标准,临时对象不能绑定到非常量引用。因此出现了警告。
有些编译器确实允许将其作为语言扩展。

:
您需要更改接口,使其接受const引用,以便绑定到临时对象。

void DoSomethingToMyClass(const MyClass& my_class_reference)
                          ^^^^^^^

或者不传递一个临时的无名对象传递一个命名对象。

void DoSomethingToMyClass(MyClass& my_class_reference);
Myclass obj;
DoSomethingToMyClass(obj);