=============================================================================
基类>组合类>自己;(如果级别相同那么顺序由定义顺序决定)
析构与构造相反;
2 如果基类没有不含参的构造函数,那么必须在构造子类对象时对其初始化
语法(子类的构造函数对父类属性进行初始化):
子类名 (参数列表) :基类1名(参数列表),基类2名)(参数列表){函数体};
⚠️:在继承中子类仅仅将父类的属性与方法继承了下来,千万不要认为
子类的对象上面还有一个父类;
⚠️:子类对象与父类对象的关系:(符号代表属性与变量)
*** 爷爷类//代代相传代代变强变多【只有三颗*】
***@@@ 爸爸类 【比爷爷类多出三个@】
***@@@$$$ 儿子类 【儿子类有更多的属性与方法】
两个b是同一个b,可以直接初始化父类的属性
只有在基类没有无参构造函数的时候这么写
可以多传几个参数,看个人需求。参数要在子类的构造函数参数列表内。
//继承中的构造与析构函数
//构造函数调用顺序是 基类>嵌套类>自己,析构相反
#include
using namespace std;
class A {
private:
int a;
public:
A(int a ) {
this->a = a;
cout << “这里是A的构造函数” << endl;
}
void print() {
cout << "A: "<<a << endl;
}
~A() {
cout << “这里是A的析构函数” << endl;
}
};
class B :public A{
private:
int b;
public:
B(int b=0) :A(b){//要在B构造函数的初始化列表对A进行初始化,
this->b = b;
cout << “这里是B的构造函数” << endl;
}
~B() {
cout << “这里是B的析构函数” << endl;
}
};
int main_01() {
B b1(2);
b1.print();//b1对象既有类A的属性,又有类B的属性;输出的是B类的print
b1.A::print();//输出类A的print;
return 0;
}
===========================================================================
子类可以初始化父类:
初始化时调用父类的拷贝构造函数;
父类的指针与引用可以指向子类;
子类有父类没有的方法,并且可以完成父类的工作;
值得注意的是:
在基类的指针或者引用与子类的对象关联时就好像指针只与子类对象
的一部分进行了关联;仅仅是用子类对象的一部分属性
初始化出来了基类的对象,并且该对象中没有子类的成员属性;
具体实现方法如下:
//基类的指针与引用可以指向子类的对象;
//子类的对象可以对父类进行初始化;
#include
using namespace std;
class A1 {
public:
int a;
int b;
public:
void print() {
cout << “A1 A1:”<<" : "<<a<<b << endl;
}
};
class B1:public A1 {
public:
int a;
int b;
public:
B1(int a, int b) {
this->a = a;
this->b = b;
A1::a = 100;
A1::b = 200;
}
void print() {
cout << " " << B1::a<<" "<< B1::b << endl;
cout << “B1 B1”<<" : "<<a<<b << endl;
}
int getA() {
return a;
}
};
int main_02() {
B1 b1(1, 2);
A1 a1= b1;//(兼容赋值原则)(子类直接给父类的对象赋值)
A1* p = NULL;
p = &b1;//将子类的地址赋给基类的指针;
A1& q = b1;//基类还可以做子类的引用;
// B1* q = NULL;
// q = &a1;也不可以进型子类的指针指向基类的对象
// B1 b2 = a1;可以将子类的对象赋值给父类的对象:不能反向操作;因为子类对象有父类没有的东西;
//分割线*******************************************
cout << “” << endl;
cout << q.a << endl;
q.print();//打印的还是A类的东西;
cout << “-----------------------------0-----” << endl;
p->print();//输出的是A类内的元素;并且调用的是A类的打印函数;
cout << p->a << endl;//打印A类的元素
b1.print();//只有这句话调用了b的打印函数
a1.print();//没有显示的对a1成员属性进行操作:但输出了100 200;如果将a1=b1去掉则输出乱码:
//由此可知b1中的A1::a与A1::b对a1中的a,b进行了初始化;
return 0;
}
===================================================================================
子类与父类难免有些成员属性会重名;由于有作用域的限制子类继承时可以将同名的属性与方法继承下来;
只需在使用时稍加注意即可:
默认情况子类在调用重名属性时会先调用自己的属性;
语法:子类对象名.重名函数;
想要调用基类的是重名属性的方法:(使用域作用符):
语法:子类对象名.基类名::重名属性;【::是域作用符】
========================================================================
在C++中一个类可以继承多个类;并且拥有他们的属性与方法;
但有时候会产生二义性
ABCD四个类继承如图所示:
A //A是BC的基类
/ \ //BC继承A后可能分别会以不同的方式初始化A
【假设A没有无参构造函数】必须由B或者C进行初始化
B C
\ /
D //D在同时继承BC,如果初始化D的对象时,
调用B还是C的构造函数去初始化A?
这就使编译器十分矛盾;产生了二义性;
解决方法;利用虚继承:virtual关键字在继承时进行限定;
【讲多态的时候会着重讲virtual关键字】
具体实现方法如下:
#include
using namespace std;
class AA {
public:
int a;
AA(int a = 0) {
this->a = a;
}
void print() {
cout << " AA" << endl;
}
};
class BB:virtual public AA {//
public:
int b;
BB(int b = 0):AA(1) {
this->b = b;
}
void print() {
cout << “BB” << endl;
前端资料汇总
开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】
我一直觉得技术面试不是考试,考前背背题,发给你一张考卷,答完交卷等通知。
首先,技术面试是一个 认识自己 的过程,知道自己和外面世界的差距。
更重要的是,技术面试是一个双向了解的过程,要让对方发现你的闪光点,同时也要 试图去找到对方的闪光点,因为他以后可能就是你的同事或者领导,所以,面试官问你有什么问题的时候,不要说没有了,要去试图了解他的工作内容、了解这个团队的氛围。
找工作无非就是看三点:和什么人、做什么事、给多少钱,要给这三者在自己的心里划分一个比例。
最后,祝愿大家在这并不友好的环境下都能找到自己心仪的归宿。