一个小引子
10多年的铜仁网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。成都全网营销的优势是能够根据用户设备显示端的尺寸不同,自动调整铜仁建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。成都创新互联从事“铜仁网站设计”,“铜仁网站推广”以来,每个客户项目都认真落实执行。
有些类之间存在特殊的关系,像下面的图一样:
定义这些类时,下级的成员除了有向上一级类的共性,还有自己的特性,这时,就可以用继承的技术,减少代码的重复
class 子类 : 继承方式 父类
#include
using namespace std;
//普通页面实现
//java页面
//class Java{
//public:
// void header(){
// cout << "首页,登录,注册(公共头部)" << endl;
// }
//
// void footer(){
// cout << "帮助中心,站内地图(公共底部)" << endl;
// }
//
// void lefter(){
// cout << "C++,Java,Phthon(公共分类列表)" << endl;
// }
//
// void conter(){
// cout << "Java学科的视频" << endl;
// }
//};
//class Python{
//public:
// ...和前面一样
// void conter(){
// cout << "Python学科的视频" << endl;
// }
//};
//class Cpp{
//public:
// ...和前面一样
// void conter(){
// cout << "C++学科的视频" << endl;
// }
//};
//继承实现页面
//公共页面类
class BagePage{
public:
void header(){
cout << "首页,登录,注册(公共头部)" << endl;
}
void footer(){
cout << "帮助中心,站内地图(公共底部)" << endl;
}
void lefter(){
cout << "C++,Java,Phthon(公共分类列表)" << endl;
}
};
//Java页面
class Java:public BagePage{
public:
void conter(){
cout << "Java学科的视频" << endl;
}
};
//Python页面
class Python:public BagePage{
public:
void conter(){
cout << "Python学科的视频" << endl;
}
};
//Cpp页面
class Cpp:public BagePage{
public:
void conter(){
cout << "C++学科的视频" << endl;
}
};
void test01(){
cout << "Java界面下载" << endl;
Java ja;
ja.header();
ja.lefter();
ja.footer();
ja.conter();
cout << "=========================" << endl;
cout << "Python界面下载" << endl;
Python py;
py.header();
py.lefter();
py.footer();
py.conter();
cout << "=========================" << endl;
cout << "C++界面下载" << endl;
Cpp cpp;
cpp.header();
cpp.lefter();
cpp.footer();
cpp.conter();
}
int main(){
test01();
return 0;
}
两次结果均是
子类中包含两大成员:1是自己增加的成员(特性) 2.是从父类中继承的过来的(共性)
继承一共3种方式
从父类继承到子类的成员,那些属于子类的对象中
父类中非静态的成员属性都会被子类继承下去(私有属性只是被编译器隐藏了)
#include
using namespace std;
class Base{
public:
int m_a;
protected:
int m_b;
private:
int m_c;
};
class Son:public Base{
public:
int m_d;
};
void test01(){
cout << "size of Son is " << sizeof(Son) << endl;
}
int main(){
test01();
return 0;
}
利用开发人员命令提示工具
构造:先父类后子类
析构:先子类后父类
当我们的子类和父类出现同名的成员,如何通过子类对象来访问到子类或父类中同名的数据呢
#include
using namespace std;
//父类:m_a = 100
//子类:m_a = 200
class Base{//父类
public:
int m_a;
Base(){
m_a = 100;
}
};
class Son:public Base{//子类
public:
int m_a;
Son(){
m_a = 200;
}
};
void test01(){
Son s;
/*=====================================================*/
cout << "子类的m_a:"<< s.m_a << endl;//直接访问
cout << "父类的m_a:" << s.Base::m_a << endl;//添加父类的作用域
/*=====================================================*/
}
int main(){
test01();
return 0;
}
如果出现同名的情况,子类中的同名函数会隐藏掉父类中所有的同名函数(包括重载函数)
#include
using namespace std;
class Base{
public:
int m_a;
Base(){
m_a = 100;
}
void func(){
cout << "父类的m_a:" << m_a << endl;
}
};
class Son:public Base{
public:
int m_a;
Son(){
m_a = 200;
}
void func(){
cout << "子类的m_a:" << m_a << endl;
}
};
void test02(){
Son s;
/*=====================================================*/
s.func();
s.Base::func();
/*=====================================================*/
}
int main(){
test02();
return 0;
}
小总结
和上面是一样的哦...
我就不写喽(嘿嘿)
emmm,复习一下访问方法
//成员
Son s;
//通过对象访问
cout << "子类的m_a:"<< s.m_a << endl;//直接访问
cout << "父类的m_a:" << s.Base::m_a << endl;//添加父类的作用域
//通过类名来访问
cout << Son::m_a << endl;
cout << Son::Base::m_a << endl;
//函数
Son s;
s.func();
s.Base::func();
Son::func();
Son::Base::func();
C++可以一个类继承多个类(一个儿子认多个父亲...)
多继承更会触发同名的问题,要注意加作用域区分
实际开发不建议使用(经典白学)
class 类名:继承方式1 父类1,继承方式2 父类2...
例子
#include
using namespace std;
//父类1是100
//父类2是200
//子类是300
class Base1{//父类1
public:
int m_a;
Base1(){
m_a = 100;
}
};
class Base2{//父类2
public:
int m_a;
Base2(){
m_a = 200;
}
};
class Son:public Base1,public Base2{//子类
public:
int m_a;
Son(){
m_a = 300;
}
};
void test01(){
Son s;
cout << "子类的m_a:" << s.m_a << endl;
cout << "父类1的m_a:" << s.Base1::m_a << endl;
cout << "父类2的m_a:" << s.Base2::m_a << endl;
}
int main(){
test01();
return 0;
}
两个派生类继承同一基类
又有某个类同时继承两个派生类
这样就叫做菱形继承啦,或是叫做钻石继承
但是会出现一些问题:
没有虚继承:
#include
using namespace std;
class Base{//虚基类
public:
int m_age;
};
class Son1: public Base{};
class Son2: public Base{};
class GrandSon:public Son1,public Son2{};
void test01(){
GrandSon gs;
gs.Son1::m_age = 18;
gs.Son2::m_age = 28;
cout << "Son1的年龄" <
加上虚继承
我的认为就是这4个类中的m_age都相当于同一个了,修改其中一个其余的全部改变。
class Son1:virtual public Base{};
class Son2:virtual public Base{};
void test01(){
...
cout << gs.m_age;
}