1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
class Date
{
private:
int m_year;
int m_month;
int m_day;
public:
Date(int year, int month, int day)
{
setDate(year, month, day);
}
// setDate() cannot be const, modifies member variables
void setDate(int year, int month, int day)
{
m_year = year;
m_month = month;
m_day = day;
}
// The following getters can all be made const
int getYear() const { return m_year; }
int getMonth() const { return m_month; }
int getDay() const { return m_day; }
};
重载的函数用const和非const版本通常是当返回值需要不同的常量。在上面的例子中,对getvalue()非const版本只非const对象的工作,但是更加灵活,我们可以用它来读写m_value(我们做分配字符串“嗨”)。
对getvalue() const版本将const或非const对象或工作,但返回const引用,以确保我们不能修改const对象的数据。
这是因为该函数的常量性是函数的签名的一部分,所以一个const和非const函数,只有常量性不同,被认为是不同的。
总结
因为通过对象的const引用是常见的,你的课应该是const的友好。这意味着任何成员函数不能修改类对象的const的状态!
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
#include <iostream>
class Date
{
private:
int m_year;
int m_month;
int m_day;
public:
Date(int year, int month, int day)
{
setDate(year, month, day);
}
void setDate(int year, int month, int day)
{
m_year = year;
m_month = month;
m_day = day;
}
int getYear() { return m_year; }
int getMonth() { return m_month; }
int getDay() { return m_day; }
};
// note: We're passing date by const reference here to avoid making a copy of date
void printDate(const Date &date)
{
std::cout << date.getYear() << "/" << date.getMonth() << "/" << date.getDay() << '\n';
}
int main()
{
Date date(2016, 10, 16);
printDate(date);
return 0;