簡體   English   中英

類型的非const引用的初始化無效

[英]Invalid initialization of non-const reference of type

在下面的代碼中,我無法將臨時對象作為參數傳遞給printAge函數:

struct Person {
  int age;
  Person(int _age): age(_age) {}
};

void printAge(Person &person) {
   cout << "Age: " << person.age << endl;
}

int main () {
  Person p(50);
  printAge(Person(50));  // fails!
  printAge(p);
  return 0;
}

我得到的錯誤是:

error: invalid initialization of non-const reference of type ‘Person&’ from an rvalue of type ‘Person’

我意識到這與將lValue傳遞給期望rValue的函數有關...有沒有辦法通過使用std :: move或其他東西將我的lValue轉換為rValue? 我嘗試了一個常量參數,但這似乎不起作用。

只需使您的打印功能通過const&接受您的參數。 這在邏輯上也是正確的,因為它不會修改您的參數。

void printAge(const Person &person) {
   cout << "Age: " << person.age << endl;
}

實際問題是另一種方式。 您正在將臨時(rvalue)傳遞給期望左值的函數。

或者,如果您有一個符合C ++ 11的編譯器,可以使用所謂的通用引用方法,通過引用折疊規則,它可以綁定到左值和右值引用:

#include <iostream>
using namespace std;

struct Person {
  int age;
  Person(int _age): age(_age) {}
};

template<typename T> // can bind to both lvalue AND rvalue references
void printAge(T&& person) {
   cout << "Age: " << person.age << endl;
}

int main () {
  Person p(50);
  printAge(Person(50));  // works now
  printAge(p);
  return 0;
}

或者,在C ++ 14中,

void printAge(auto&& person) {
   cout << "Age: " << person.age << endl;
}

如果運行g ++或gcc編譯器,則代碼不起作用。 您需要將const添加到void printAge(const Person &person) 但是,在Visual Studio中它可以正常工作。 我已經測試了VS2010和VS2012,以下兩個代碼都可以正常工作。

 #include<iostream>

using namespace std;
struct Person {
  int age;
  Person(int _age): age(_age) {}
};

void printAge(Person &person) {
   cout << "Age: " << person.age << endl;
}

int main () {
  Person p(50);
  printAge(Person(50));  // DOES NOT fail!
  printAge(p);
  return 0;
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM