1234567891011121314151617181920212223242526class 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的状态!
2345678910111213141516171819202122232425262728293031323334353637383940#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 datevoid printDate(const Date &date){ std::cout << date.getYear() << "/" << date.getMonth() << "/" << date.getDay() << '\n';} int main(){ Date date(2016, 10, 16); printDate(date); return 0;
0 0