1. 程式人生 > >C++ const修飾類成員的說明

C++ const修飾類成員的說明

obj string code ++ tdi 原因 會有 cal 修改

#include <iostream>
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
using namespace std;
/*

  • A1 const 修飾一個類中成員變量,則此變量必要用初始化列表來進行初始化。
  • A2 const 修飾一個類中成員函數,則表示此成員函數不會修改類中所有成員變量。
  • A3 const 修飾一個函數入參的引用時,表示此引用的內容不得在此函數中發生變化。
  • A3.1 const 修飾一個函數的“引用入參”時,那麽這個函數只可以使用入參的?const 的成員函數
  • */
    class Student{

    string m_name;
    const int m_id; //A1
    int m_score;
    public:
    int show_info_no_const(void)
    {
    cout <<"no const function: name "<< m_name << ", id " << m_id<<endl;
    return 0;
    }
    int show_info(void) const
    {
    cout <<"name "<< m_name << ", id " << m_id<<endl;

    // m_score=90; //A2 此處會有編譯錯誤,原因就是show_info 被const來修飾了。
    return 0;
    }
    void set_name(char new_name);
    ~Student();
    Student():m_id(999){};
    Student(const char
    h);
    Student(const Student &obj);
    };
    Student::Student(const Student &obj):m_id(888)//A1
    {
    cout <<"call copy constructor "<<endl;
    m_name = obj.m_name;
    }
    #if 1
    Student::Student(const char* h):m_id(777)
    {
    m_name=h;

}
#endif

#if 1
Student::~Student()
{
}

void Student::set_name(char* new_name)
{
m_name=new_name;
//m_id=9;//A1 m_id是不可以再被修改的。

}
#endif
//測試A3.1
void show_student(const Student& Stu) //A3
{
Stu.show_info();
// Stu.show_info_no_const(); //A3.1 此函數實際上沒有改變Stu的值 ,但是由於它沒有使用const進行修飾,所以發生了const屬性丟失的情況。
}
int main()
{
Student A1;
A1.set_name("A1");
A1.show_info();
Student A2("abl");
A2.show_info();

Student A3(A2);
A3.show_info();

return 0;

}

C++ const修飾類成員的說明