类成员函数后边加const

  本文主要整理自stackoverflow上的一个对问题Meaning of “const” last in a C++ method declaration?的回答。

测试1

  对于下边的程序,关键字const的作用在哪里?

 1 #include <iostream>
 2 
 3 class MyClass
 4 {
 5 private:
 6     int counter;
 7 public:
 8     void Foo()
 9     { 
10         std::cout << "Foo" << std::endl;    
11     }
12 
13     void Foo() const
14     {
15         std::cout << "Foo const" << std::endl;
16     }
17 
18 };
19 
20 int main()
21 {
22     MyClass cc;
23     const MyClass& ccc = cc;
24     cc.Foo();
25     ccc.Foo();
26 
27     return 0;
28 }

  程序输出:

Foo
Foo const

  当我们将函数“void Foo()”注释掉,测试程序将会输出:

Foo const
Foo const

  当我们将“void Foo() const”注释掉,测试程序不通过。因为“void Foo()”并不是返回一个const的MyClass,所以“const MyClass& ccc = cc”这一句是通不过编译的。

  

  综上,对函数“void Foo() const”而言,它不能够修改类MyClass的所有成员变量的值(即此时类MyClass是const的),否则将编译不通过。

  所以下边的程序也是通不过编译的:

 1     void Foo()
 2     {
 3         counter++; //this works
 4         std::cout << "Foo" << std::endl;    
 5     }
 6 
 7     void Foo() const
 8     {
 9         counter++; //this will not compile
10         std::cout << "Foo const" << std::endl;
11     }

测试2

  对于测试1的程序,我们只要将成员变量counter设置为mutable就可以在“void Foo() const”函数中修改counter的值了,具体测试程序如下:

 1 #include <iostream>
 2 
 3 class MyClass
 4 {
 5 private:
 6     mutable int counter;
 7 public:
 8 
 9     MyClass() : counter(0) {}
10 
11     void Foo()
12     {
13         counter++;
14         std::cout << "Foo" << std::endl;    
15     }
16 
17     void Foo() const
18     {
19         counter++;
20         std::cout << "Foo const" << std::endl;
21     }
22 
23     int GetInvocations() const
24     {
25         return counter;
26     }
27 };
28 
29 int main(void)
30 {
31     MyClass cc;
32     const MyClass& ccc = cc;
33     cc.Foo();
34     ccc.Foo();
35     std::cout << "The MyClass instance has been invoked " << ccc.GetInvocations() << " times" << endl;
36 
37     return 0;      
38 }

 

posted @ 2015-08-05 23:43  峰子_仰望阳光  阅读(1374)  评论(0编辑  收藏  举报