lvalue

    1熱度

    1回答

    學習左值和右值。定義是什麼可以是「地址」是左值,否則,它是右值。 我檢查了運算符優先級,前綴和後綴增量的優先級都高於「運算符的地址」。 對於以下兩個示例,任何人都可以解釋一下爲什麼第一個「& ++ value1」是一個左值,而第二個「& value1 ++」是右值。 我對這兩種情況的錯誤理解是:pValue1指向value1變量。在建立地址關聯之前或之後,無論value1變爲8,value1變量總

    0熱度

    1回答

    所以假設我們用C以下++:a=b=5;這基本上意味着a=(b=5); 如果我們有a=5;我知道5是一個文字,因此它是R-價值。 a是一個L值。這同樣適用於b=5; 我現在想知道,會發生什麼,如果我們分別寫a=b=5;a=(b=5); 我現在可以說以下? 對於a,b=5是一個R值,a是一個L值。此外,b是一個L值,而5是一個R值。 什麼是a的R值?

    0熱度

    1回答

    從下在果殼: 左值是指定一個對象的表達式,並且它可以 上的賦值運算符的左側出現。 左值總是可以被解析爲相應的對象的 地址,除非對象是一個位字段或使用寄存器存儲類聲明的變量。 根據來自報價第二句,當對象是 比特值或使用寄存器存儲類聲明的變量, 一個左值不能被解析爲相應的對象的地址。 這是爲什麼? 給定一個左值不能被解析爲相應的對象的 地址,怎麼能左值指定的對象,出現在賦值運算符的 左側? 我認爲,以

    3熱度

    1回答

    我正在練習描述Here的東西來學習左值和右值的概念。但是,當我如下創建自己的示例時,我發現它編譯並運行時沒有任何錯誤(使用VS2017)。我已經瞭解到,在情況1下,它與致電 produceA(10).operator=(A()) 相同,因此是合法的。但是,我仍然不明白爲什麼情況2和3是允許的。事實上,案例2甚至與文中給出的例子相矛盾。我真的得到了這兩種情況下的右值的地址嗎?他們是否會導致未定義

    4熱度

    2回答

    考慮下面的代碼左值:如果您嘗試運行它 #include <iostream> using namespace std; class X { int i; public: X(int ii = 0); }; X::X(int ii) { i = ii; } int a; X f1() { return X(); } int f2() { return a

    13熱度

    1回答

    我試圖理解C++ 11中的左值和右值。所以我寫了一個測試代碼: int x = 10; int foo() { return x; } int& bar() { return x; } int&& baz() { return 10; } int main() { int& lr1 = 10; // error: lvalue references rvalue i

    1熱度

    1回答

    規範是重載括號()運算符來訪問和分配矩陣的元素,但是,我正在努力弄清楚我的重載函數需要返回什麼。 的簡要主: //The .h files and everything has been included, my other functions work just not this one cout << "Test(): " << endl; m0(0,0) = 17.25; m0(1,5

    1熱度

    2回答

    class Vec3{ private: float x, y, z; public: Vec3() = default; Vec3(const float c) {x = c; y = c; z = c;} static Vec3& normalize(Vec3& v) {/* normalize */ return v;} }; Vec

    0熱度

    1回答

    當我嘗試指定一個枚舉值時,我在C++中有一個可怕的程序。 當我嘗試將Wall或Free等分配給sokoban.board[j,i]時,存在該錯誤。 bool loadLevel(ifstream &stream, tSokoban &sokoban, int level) { bool ok = false; string levelStr, levelFile = " ",

    6熱度

    2回答

    我瞭解左值的幾件事數組,但我不明白下面的代碼是如何給出一個錯誤: #include<stdio.h> void foo(int *); int main() { int i=10; foo((&i)++); } void foo(int *p) { printf("%d",*p); } 6:13:錯誤:需要左值的遞增操作數 FOO(( & i)