为什么int x {y = 5}是可能的?

cou*_*er0 10 c++ initialization declaration assignment-operator

int main() {
    int y;
    int x{ y = 5 };
    //x is 5
}
Run Code Online (Sandbox Code Playgroud)

由于y = 5不是可计算的表达式,这怎么可能?

另外,为什么编译器或IDE不会抱怨main()不返回int?

lub*_*bgr 16

由于y = 5不是可计算的表达式,这怎么可能?

这是一个赋值,赋值产生值,即“左操作数的cv不合格类型”,请参见[expr.ass / 3]。因此,y = 5结果y5,用于初始化x

关于第二个问题,请参阅main(或[basic.start.main / 5])上的cppreference :

main函数的主体不需要包含该return语句:如果控制在未遇到return语句的情况下到达了main的末尾,则其效果就是execute return 0;

因此,编译器或IDE return在末尾警告您丢失语句main将是完全错误的。诚然,您应该始终return从非void函数execptmain对象来反对这一事实…………我想,出于历史原因。

  • 表达式可以求出值,但是只有一个函数可以“返回”一个值。学究的 (2认同)

Vla*_*cow 10

我将从你的最后一个问题开始

另外,为什么编译器或IDE不会抱怨main()不返回int?

根据C ++标准(6.6.1主要功能)

5 main中的return语句的作用是保留main函数(使用自动存储持续时间销毁所有对象)并使用返回值作为参数调用std :: exit。如果控制从main的复合语句的末尾流出,则效果等效于操作数为0的返回(另请参见18.3)。

相对于这个问题

由于y = 5不是可计算的表达式,这怎么可能?

来自C ++标准(8.18赋值和复合赋值运算符)

1赋值运算符(=)和复合赋值运算符都从右到左分组。它们都需要可修改的左值作为其左操作数,并返回引用左操作数的左值。

Sp此声明

int x{ y = 5 };
Run Code Online (Sandbox Code Playgroud)

可以等效地分为两个语句

y = 5;
int x{ y };
Run Code Online (Sandbox Code Playgroud)

此外,在C ++中,您甚至可以通过以下方式引用变量y

int &x{ y = 5 };
Run Code Online (Sandbox Code Playgroud)

这是一个示范节目

#include <iostream>

int main() 
{
    int y;
    int &x{ y = 5 };    

    std::cout << "y = " << y << '\n';

    x = 10;

    std::cout << "y = " << y << '\n';
}
Run Code Online (Sandbox Code Playgroud)

它的输出是

y = 5
y = 10
Run Code Online (Sandbox Code Playgroud)

你可以这样声明

int x{ y = 5 };
Run Code Online (Sandbox Code Playgroud)

改写也一样

int x = { y = 5 };
Run Code Online (Sandbox Code Playgroud)

但是要考虑到这两个声明(与上述声明类似)之间存在差异。

auto x{ y = 5 };
Run Code Online (Sandbox Code Playgroud)

auto x = { y = 5 };
Run Code Online (Sandbox Code Playgroud)

在第一个声明中,变量x的类型为int。在第二个声明中,变量x的类型为std::initializer_list<int>

为了使差异更明显,请参见如何输出对象的值。

#include <iostream>

int main() 
{
    int y;
    auto x1 { y = 5 };  

    std::cout << "x1 = " << x1 << '\n';

    auto x2 = { y = 10 };   

    std::cout << "*x2.begin()= " << *x2.begin() << '\n';

    std::cout << "y = " << y << '\n';

    return 0;
}
Run Code Online (Sandbox Code Playgroud)

程序输出为

x1 = 5
*x2.begin()= 10
y = 10
Run Code Online (Sandbox Code Playgroud)