概念:
面向对象(Object Oriented)是软件开发方法,一种编程范式。面向对象是一种对现实世界理解和抽象的方法,是计算机编程技术发展到一定阶段后的产物。
面向对象是相对于面向过程来讲的,面向对象方法,把相关的数据和方法组织为一个整体来看待,从更高的层次来进行系统建模,更贴近事物的自然运行模式。
面向过程 函数 + 数据
面向对象 OOP 对象
对象 —》 类 ----》 自定义的数据类型
类:
将变量和函数打包放在一起
用变量模拟现实物体的属性 ------ 颜色,大小
用函数模拟现实物体的行为 ------ 吃饭,睡觉
this指针:指向当前对象的指针
自动加在:成员方法第一个形参,成员方法体内使用到成员的 地方,成员方法调用时候加上第一个实参
构造函数:
会在对象构造的时候自动调用
如果没有自己实现构造函数,编译器会自动为我们生成一个默认构造函数–啥都不做
如果自己实现了构造函数,编译器就不生成了
构造函数可以重载
析构函数:
会在对象生存周期满的时候,自动调用的函数
如果没有自己实现析构函数,编译器会自动生成一个析构函数–啥都不干
如果自己实现了析构,编译器就不会生成
析构函数不能重载
class Person
{
public:
//成员变量
char* _name;
int _age;
int _sex;
Person()//默认构造函数就是不加额外参数的构造函数
{
cout << "Person()" << endl;
}
//构造函数
Person(const char* name, int age, int sex)
{
cout << "Person(const char* name, int age, int sex)" << endl;
_name = new char[strlen(name) + 1];
for (int i = 0; i < strlen(name) + 1; i++)
{
_name[i] = name[i];
}
_age = age;
_sex = sex;
}
//析构函数
~Person()
{
cout << "~Person()" << endl;
delete[]_name;
}
/*
void destroy()
{
delete[]_name;
}
*/
void init(const char* name,int age,int sex)
{
_name = new char[strlen(name) + 1];
for (int i = 0; i < strlen(name) + 1; i++)
{
_name[i] = name[i];
}
_age = age;
_sex = sex;
}
//成员方法
void eat(/* Person* this */)
{
cout << this->_name <<"::eat eat eat ……" << endl;
}
void walk()
{
cout <<_name<< "::walk walk walk ……" << endl;
}
};
int data;
Person per3;
int main()
{
#if 0
Marr arr1;
Marr* arr = new Marr;
init(arr);
show(arr);
for (int i = 0; i < 10; i++)
{
push_back(arr, i);
}
show(arr);
pop_back(arr);
show(arr);
int pos = find(arr, 5);
cout << pos << endl;
insert(arr, pos, 999);
show(arr);
sort(arr);
show(arr);
#endif
#if 0
Person per1;//构造了一个Person类型的对象
const char* p = "zhangsan";
per1._name = new char[strlen(p) + 1];
for (int i = 0; i < strlen(p) + 1; i++)
{
per1._name[i] = p[i];
}
per1.eat(/* &per1 */);
per1.walk();
#endif
Person *per2 = new Person("zhangsan", 23, 1);
//per2.init("zhangsan", 23, 1);
per2->eat();
per2->walk();
cout << "===================" << endl;
delete per2;
cout << "===================" << endl;
Person per4;
//Person per3();
return 0;
}