模板类与继承

embedded/2024/10/18 21:22:24/

1模板类继承普通类(常见)

#include<iostream>
using namespace std;
class AA
{
public:int m_a;AA(int a) :m_a(a) { cout << "调用了AA的构造函数\n"; }void func1() { cout << "调用func1()函数 :m_a = " << m_a << endl; }
};
template <class T1,class T2>
class BB
{
public:T1 m_x;T2 m_y;BB(const T1 x, const T2 y) :m_x(x), m_y(y) { cout << "调用了BB的构造函数,\n"; }void func2() { cout << "调用了func2()函数:x = " << m_x << "y = "<<m_y<<endl; ; }
};
int main() {BB<int, string> bb(8, "zhongge");bb.func2();return 0;
}

现在AA BB没有任何关系,如果把普通类作为基类,把模板类BB作为子类,继承AA。

#include<iostream>
using namespace std;\
class AA
{
public:int m_a;AA(int a) :m_a(a) { cout << "调用了AA的构造函数\n"; }void func1() { cout << "调用func1()函数 :m_a = " << m_a << endl; }
};
template <class T1,class T2>
class BB:public AA
{
public:T1 m_x;T2 m_y;BB(const T1 x, const T2 y) :m_x(x), m_y(y) { cout << "调用了BB的构造函数,\n"; }void func2() { cout << "调用了func2()函数:x = " << m_x << "y = "<<m_y<<endl; ; }
};
int main() {BB<int, string> bb(8, "zhongge");bb.func2();return 0;
}

让BB继承AA但是出现了错误:AA没有合适的默认的构造函数。

继承的时候派。生类如何构造基类:要在派生类BB构造函数的初始化列表中指明基类的构造函数。

#include<iostream>
using namespace std;\
class AA
{
public:int m_a;AA(int a) :m_a(a) { cout << "调用了AA的构造函数\n"; }void func1() { cout << "调用func1()函数 :m_a = " << m_a << endl; }
};
template <class T1,class T2>
class BB:public AA
{
public:T1 m_x;T2 m_y;BB(const T1 x, const T2 y,int a) :AA(a),m_x(x), m_y(y) { cout << "调用了BB的构造函数,\n"; }void func2() { cout << "调用了func2()函数:x = " << m_x << " ,y = "<<m_y<<endl; ; }
};
int main() {BB<int,string> bb(8, "zhongge",3);bb.func2();bb.func1();return 0;
}
调用了AA的构造函数
调用了BB的构造函数,
调用了func2()函数:x = 8 ,y = zhongge
调用func1()函数 :m_a = 3C:\Users\代伟业\Desktop\C++\初始化列表\ConsoleApplication1\x64\Debug\ConsoleApplication1.exe (进程 19556)已退出,代码为 0。
按任意键关闭此窗口. . .

2普通类继承模板类的实例版本

#include<iostream>
using namespace std;
template <class T1, class T2>
class BB
{
public:T1 m_x;T2 m_y;BB(const T1 x, const T2 y) : m_x(x), m_y(y) { cout << "调用了BB的构造函数,\n"; }void func2() { cout << "调用了func2()函数:x = " << m_x << " ,y = " << m_y << endl; ; }
};class AA :public BB <int,string>
{
public:int m_a;AA(int a,int x,string y) :BB(x,y),m_a(a) { cout << "调用了AA的构造函数\n"; }void func1() { cout << "调用func1()函数 :m_a = " << m_a << endl; }
};
int main() {AA aa(3,8,"zhongge");aa.func2();aa.func1();return 0;
}
调用了BB的构造函数,
调用了AA的构造函数
调用了func2()函数:x = 8 ,y = zhongge
调用func1()函数 :m_a = 3C:\Users\代伟业\Desktop\C++\初始化列表\ConsoleApplication1\x64\Debug\ConsoleApplication1.exe (进程 7360)已退出,代码为 0。
按任意键关闭此窗口. . .

3普通类继承模板类

#include<iostream>
using namespace std;
template <class T1, class T2>
class BB
{
public:T1 m_x;T2 m_y;BB(const T1 x, const T2 y) : m_x(x), m_y(y) { cout << "调用了BB的构造函数,\n"; }void func2() { cout << "调用了func2()函数:x = " << m_x << " ,y = " << m_y << endl; ; }
};
template <class T1, class T2>
class AA :public BB <T1,T2>
{
public:int m_a;AA(int a,T1 x,T2 y) :BB<T1,T2>(x,y),m_a(a) { cout << "调用了AA的构造函数\n"; }void func1() { cout << "调用func1()函数 :m_a = " << m_a << endl; }
};
int main() {AA<int,string> aa(3,8,"zhongge");aa.func2();aa.func1();return 0;
}

4模板类继承模板类。

#include<iostream>
using namespace std;
template <class T1, class T2>
class BB
{
public:T1 m_x;T2 m_y;BB(const T1 x, const T2 y) : m_x(x), m_y(y) { cout << "调用了BB的构造函数,\n"; }void func2() { cout << "调用了func2()函数:x = " << m_x << " ,y = " << m_y << endl; ; }
};
template <class T1, class T2>
class AA :public BB <T1,T2>
{
public:int m_a;AA(int a,T1 x,T2 y) :BB<T1,T2>(x,y),m_a(a) { cout << "调用了AA的构造函数\n"; }void func1() { cout << "调用func1()函数 :m_a = " << m_a << endl; }
};
template <class T,class T1,class T2>
class CC:public BB<T1,T2>
{public:T m_a;CC(const T a, const T1 x,const T2 y) :BB<T1, T2>(x, y), m_a(a) { cout << "调用leCC的构造函数\n"; }void func3() { cout << "调用func1()函数 :m_a = " << m_a << endl; }
};
int main() {AA<int,string> aa(3,8,"zhongge");aa.func2();aa.func1();CC <int,int,string> cc(3, 8, "我是一只傻傻鸟");return 0;
}

5模板类继承模板参数给出的基类(不能是模板类)

#include<iostream>
using namespace std;class AA
{
public:AA(){ cout << "调用leAA的构造函数\n"; }AA(int a) { cout << "调用leAA(int a)的构造函数"; }
};
class BB
{
public:BB() { cout << "调用leBB的构造函数\n"; }BB(int a) { cout << "调用leBB(int a)的构造函数"; }
};
template <class T>
class CC:public T
{public:CC():T() { cout << "调用leCC的构造函数\n"; }CC(int a):T(a) { cout << "调用leCC(int a)的构造函数"; }
};int main() {CC<AA> ca1;//AA作为基类CC<BB> cb2;//BB作为基类return 0;
}


http://www.ppmy.cn/embedded/51037.html

相关文章

技术分享 | 基于 API 解析的 Python 爬虫

最近各大高校纷纷翻拍 Coincidence 抖肩舞&#xff0c;需要对这种流行现象进行数据分析。数据分析首先需要有数据&#xff0c;本文介绍了爬取 B 站相应视频的评论、弹幕、播放量、点赞数等数据的方法。爬虫有多种实现方法&#xff0c;大型的网络爬虫多基于成熟的爬虫框架&#…

AJAX 数据库

AJAX 数据库 1. 引言 AJAX&#xff08;Asynchronous JavaScript and XML&#xff09;是一种流行的网络开发技术&#xff0c;它允许网页在不重新加载整个页面的情况下与服务器交换数据和更新部分网页内容。AJAX技术与数据库的结合&#xff0c;为现代网络应用提供了更加丰富和动…

MacOS - 启动台多了个『卸载 Adobe Photoshop』

问题描述 今天安装好了 Adobe Ps&#xff0c;但是发现启动台多了个『卸载 Adobe Photoshop』强迫症又犯了&#xff0c;想把它干掉&#xff01; 解决方案 打开访达 - 前往 - 资源库&#xff0c;搜索要卸载的名字就可以看到&#xff0c;然后移除到垃圾筐

BSP驱动教程-CAN/CANFD/CANopen知识点总结分享

学习知识点整理&#xff1a; CAN 总线的前世今生&#xff1a; https://www.armbbs.cn/forum.php?modviewthread&tid104480 wikibai百科CAN总线&#xff1a; https://en.wikipedia.org/wiki/CAN_bus 瑞萨CAN入门教程&#xff1a; https://www.armbbs.cn/forum.php?m…

防火墙规则来阻止攻击者的 IP 地址

1. iptables 要禁止服务器与特定 IP 地址的通信&#xff0c;可以使用防火墙来设置规则。在 Ubuntu 上&#xff0c;iptables 是一个常用的防火墙工具。以下是使用 iptables 设置禁止与特定 IP 通信的步骤&#xff1a; 阻止所有进出的通信 如果你想阻止服务器与特定 IP 地址的…

如何开发一套基于C#和.NET 6.0手术麻醉系统? 手术麻醉系统源码

如何开发一套基于C#和.NET 6.0手术麻醉系统&#xff1f; 手术麻醉系统源码 基于C#和.NET 6.0开发的手术麻醉系统是一个涉及多个层面的复杂项目。 以下是一个概述性的步骤&#xff0c;帮助你开始这个项目&#xff1a; 一、项目规划和需求分析 1、确定项目目标&#xff1a;明确…

雷池社区版自动SSL

正常安装雷池&#xff0c;并配置站点&#xff0c;暂时不配置ssl 不使用雷池自带的证书申请。 安装&#xff08;acme.sh&#xff09;&#xff0c;使用域名验证方式生成证书 先安装git yum install git 或者 apt-get install git 安装完成后使用 git clone https://gitee.com/n…

C++中的封装、继承和多态的定义

在C中&#xff0c;封装、继承和多态是面向对象编程&#xff08;OOP&#xff09;的三个核心概念。这些概念有助于创建可重用、可扩展和可维护的代码。下面是这三个概念的详细解释&#xff1a; 封装&#xff08;Encapsulation&#xff09; 封装是隐藏对象的属性和实现细节&…