c++ - const 类成员的自动扣除

标签 c++ c++14 auto

以下两种访问私有(private)常量类成员的实现有什么区别?

// Auto& (compile ok)
class Foo {
  private:
    const int _foo;
  public:
    Foo(const int& in) : _foo(in) {}
    auto& foo() { return _foo; }
}

// Explicit type (compiler error)
class Foo {
  private:
    const int _foo;
  public:
    Foo(const int& in) : _foo(in) {}
    int& foo() { return _foo; }
}

使用 auto 编译器不会报错,但显式 int 类型声明实际上会给出编译器错误(这是由于常量)。在这种情况下,auto 推导了什么?

最佳答案

由于 _fooconst int 类型,auto 指的是 const int。将您的“显式类型”代码更改为返回 const int&,编译器应该不会再提示了。

关于c++ - const 类成员的自动扣除,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36563757/

相关文章:

c++ - 限制多个模板参数友元函数可访问的类实例的范围

c++ - GCC 中的通用 lambda

c++ - 没有定义的自动变量声明

C++11 模板方法中的自动返回类型

c++ - 如何初始化多种类型对象的自动类型数组

java - 为什么用 C++ 编写的 BRMS 不如用 Java 编写的 BRMS 有用?

c++ - 在具有容量/调整大小的类中初始化 vector

c++ - OpenCV - 如果从一个线程调用两次,imshow 会挂起

c++ - 在奇怪的二叉树中搜索节点

c++ - thread_local 静态类在程序退出时在无效地址处被销毁