4 类和对象
C++面向对象的三大特性为:封装、继承、多态
C++认为万事万物都皆为对象,对象上有其属性和行为
例如:
? 人可以作为对象,属性有姓名、年龄、身高、体重…,行为有走、跑、跳、吃饭、唱歌…
? 车也可以作为对象,属性有轮胎、方向盘、车灯…,行为有载人、放音乐、放空调…
? 具有相同性质的对象,我们可以抽象称为类,人属于人类,车属于车类
4.3 C++对象模型和this指针
4.3.1 成员变量和成员函数分开存储
在C++中,类内的成员变量和成员函数分开存储
- 空对象占一个字节;
- c++编译器会给每一个空对象也分配一个字节的空间,是为了区分空对象占内存的位置
- 每个空对象也应该有一个独一无二的内存地址。
- 非静态成员变量,属于类的对象上
- 静态成员变量,不属于类的对象上
- 非静态成员函数,不属于类的对象上
- 静态成员函数,不属于类的对象上
- 非静态成员变量,属于类的对象上,why?
空对象本来占1个字节,在添加非静态成员变量【int】后,占4个字节。 总结:只有非静态成员变量才属于类的对象上。
class Person {
public:
Person() {
mA = 0;
}
int mA;
static int mB;
void func() {
cout << "mA:" << this->mA << endl;
}
static void sfunc() {
}
};
int Person::mB=0;
int main() {
cout << sizeof(Person) << endl;
system("pause");
return 0;
}
4.3.2 this指针概念
通过4.3.1我们知道在C++中成员变量和成员函数是分开存储的 每一个非静态成员函数只会诞生一份函数实例,也就是说多个同类型的对象会共用一块代码 那么问题是:这一块代码是如何区分那个对象调用自己的呢? c++通过提供特殊的对象指针,this指针,解决上述问题。this指针指向被调用的成员函数所属的对象 this指针是隐含每一个非静态成员函数内的一种指针。 this指针不需要定义,直接使用即可。 this指针的用途:
- 当形参和成员变量同名时,可用this指针来区分
- 在类的非静态成员函数中返回对象本身,可使用return *this
class Person
{
public:
Person(int age)
{
this->age = age;
}
Person& PersonAddPerson(Person &p)
{
this->age += p.age;
return *this;
}
int age;
};
void test01()
{
Person p1(10);
cout << "p1.age = " << p1.age << endl;
Person p2(10);
p2.PersonAddPerson(p1).PersonAddPerson(p1).PersonAddPerson(p1);
cout << "p2.age = " << p2.age << endl;
}
int main() {
test01();
system("pause");
return 0;
}
4.3.3 空指针访问成员函数
C++中空指针也是可以调用成员函数的,但是也要注意有没有用到this指针 如果用到this指针,需要加以判断保证代码的健壮性 示例:
class Person {
public:
void ShowClassName() {
cout << "我是Person类!" << endl;
}
void ShowPerson() {
if (this == NULL) {
return;
}
cout << mAge << endl;
}
public:
int mAge;
};
void test01()
{
Person * p = NULL;
p->ShowClassName();
p->ShowPerson();
}
int main() {
test01();
system("pause");
return 0;
}
4.3.4 const修饰成员函数
常函数:
class Person {
public:
Person() {
m_A = 0;
m_B = 0;
}
void ShowPerson() const {
this->m_B = 100;
}
void MyFunc() const {
}
public:
int m_A;
mutable int m_B;
};
void test01() {
const Person person;
cout << person.m_A << endl;
person.m_B = 100;
person.MyFunc();
}
int main() {
test01();
system("pause");
return 0;
}
|