C++学习笔记九--模版
目录
前言
1.函数模版
1.函数模版的概念和定义
2.函数模版的实例化
2.类模版
1.类模版的概念和定义
2.类模版的实例化
3.示例代码
前言
这篇文章介绍下C++中的模版,包括函数模版和类模版。
1.函数模版
在编程的过程中,编写函数都会考虑将其写成模版函数,编写类的时候都会考虑将其写成类模版,从而减少不必要的重复。
1.函数模版的概念和定义
函数模版是一些列相关函数的模型或者样板,这些函数的源代码形式相同,只是所针对的数据类型不同。
函数模版的声明格式如下:
template<模版形参表声明><函数声明>
其中模版形参可以是以下几种形式:
1.typename<参数名>
2.class <参数名>
3.<类型修饰><函数名>
在上面的三种形式中,前两种是等价的。也就是说在声明函数模的时候,关键字typename和class功能一致。使用typename或class声明的参数称为虚拟类型参数;使用类型修饰声明的参数称为常规参数,在形式上与普通的函数参数声明相同。格式中的<函数声明>与一般函数声明类似,只是某些类型修饰符被虚拟类型参数所替代。
例如我们定义个add函数模版,代码如下:
template <class T>
T add(T a, T b) {return a + b;
}
也可以使用typaneme声明函数模版:
template <typename T>
T add(T a, T b) {return a + b;
}
在上面的函数模版声明的定义中,T是一个虚拟类型参数,它既可以做函数的返回值类型,又可以做函数的形参的类型,还可以做函数体内变量的类型。类的成员函数也可以声明为函数模版。
2.函数模版的实例化
模版函数值得是函数模版中声明的函数。
定义好函数模版之后,编译系统将依据每一次对模版函数调用时所使用的数据类型生成适当的调用代码,并生成相应的函数版本。编译系统生成函数模版的某个具体版本的过程称为函数模版的实例化,每一个实例就是一个函数的定义。在实例化的过程中,用实参的实际类型代替虚拟类型。
上述的add函数实例化的代码如下:
#include <iostream>
using namespace std;template <typename T>
T add(T a, T b) {return a + b;
}int main(int argc, const char * argv[]) {int a = 1,b = 2;int c = add<int>(a,b);cout<<"整型add函数调用:"<<a<<"\t+\t"<<b<<"\t=\t"<<c<<endl;float a1 = 1.1,b1 = 2.1;float c1 = add<float>(a1,b1);cout<<"float类型调用add函数:"<<a1<<"\t+\t"<<b1<<"\t=\t"<<c1<<endl;double a3 = 1.22,b3 = 2.222;double c3 = add<double>(a3,b3);cout<<"double类型调用add函数:"<<a3<<"\t+\t"<<b3<<"\t=\t"<<c3<<endl;return 0;
}
2.类模版
1.类模版的概念和定义
类模版指的是一系列相关类的模版或者样板,这些类的成员组成相同,成员函数的源代码形式相同,所不同的只是针对的类型。
类模版声明的格式如下:
template<模版形参声明><类声明>
2.类模版的实例化
类模版的实例化格式如下
类名 <模版实参表><对象名>
或者
类名 <模版实参表><对象名>(构造函数实参表)
下面的例子中展示了类模版的用法。
#include <iostream>
using namespace std;template <class T>
class Operates {T a;
public:Operates(){}Operates(T a){this->a = a;}void display(){cout<<"a="<<a<<endl;}T add(T b){this->a += b;display();return this->a;}T sub(T b){this->a -= b;display();return this->a;}T mult(T b){this->a *= b;display();return this->a;}T div(T b){this->a /= b;display();return this->a;}
};int main(int argc, const char * argv[]) {Operates<int> a(10);int b(10);a.add(b);a.sub(b);a.mult(b);a.div(b);return 0;
}
3.示例代码
1.用函数模版实现3个数值按照从最小值到最大值排序的程序
#include <iostream>
using namespace std;// 模板函数,用于交换两个值
template<typename T>
void mySwap(T& a, T& b) {T temp = a;a = b;b = temp;
}// 模板函数,用于对三个数值进行排序
template<typename T>
void sortThreeValues(T& a, T& b, T& c) {if (a > b) {mySwap(a, b);}if (b > c) {mySwap(b, c);}if (a > b) {mySwap(a, b);}
}int main(int argc, const char * argv[]) {int x = 1,y = 3,z = 2;//调用函数排序sortThreeValues(x, y, z);cout<<"排序之后的数据:\t"<<x<<"\t"<<y<<"\t"<<z<<endl;return 0;
}
2.利用函数模版设计一个求数组元素中和的函数,并检验
#include <iostream>
using namespace std;// 模板函数,用于交换两个值
template<typename T>
void mySwap(T& a, T& b) {T temp = a;a = b;b = temp;
}// 模板函数,用于对三个数值进行排序
template<typename T>
void sortThreeValues(T& a, T& b, T& c) {if (a > b) {mySwap(a, b);}if (b > c) {mySwap(b, c);}if (a > b) {mySwap(a, b);}
}template <typename T,size_t N>
T sumArray(const T (&arr)[N]) {T sum = 0;for (size_t i = 0; i< N ; i++) {sum += arr[i];}return sum;
}int main(int argc, const char * argv[]) {// 定义一个整型数组int intArray[] = {1, 2, 3, 4, 5};// 计算整型数组的和int intSum = sumArray(intArray);cout << "Sum of integers: " << intSum << endl;// 定义一个双精度浮点型数组double doubleArray[] = {1.1, 2.2, 3.3, 4.4, 5.5};// 计算双精度浮点型数组的和double doubleSum = sumArray(doubleArray);cout << "Sum of doubles: " << doubleSum << endl;return 0;
}
3.重载上题中的函数模版,使其能够进行两个数组的求和
#include <iostream>
using namespace std;// 函数模板,用于计算数组元素的和
template<typename T, size_t N>
T sumArray(const T (&arr)[N]) {T sum = 0;for (size_t i = 0; i < N; ++i) {sum += arr[i];}return sum;
}// 重载函数模板,用于计算两个数组对应元素的和
template<typename T, size_t N>
T sumArray(const T (&arr1)[N], const T (&arr2)[N]) {T sum = 0;for (size_t i = 0; i < N; ++i) {sum += arr1[i] + arr2[i];}return sum;
}int main(int argc, const char * argv[]) {// 定义两个整型数组int intArray1[] = {1, 2, 3, 4, 5};int intArray2[] = {6, 7, 8, 9, 10};// 计算两个整型数组的和int intSum = sumArray(intArray1, intArray2);cout << "Sum of integers: " << intSum << endl;// 定义两个双精度浮点型数组double doubleArray1[] = {1.1, 2.2, 3.3, 4.4, 5.5};double doubleArray2[] = {6.6, 7.7, 8.8, 9.9, 10.0};// 计算两个双精度浮点型数组的和double doubleSum = sumArray(doubleArray1, doubleArray2);cout << "Sum of doubles: " << doubleSum << endl;return 0;
}
相关文章:
C++学习笔记九--模版
目录 前言 1.函数模版 1.函数模版的概念和定义 2.函数模版的实例化 2.类模版 1.类模版的概念和定义 2.类模版的实例化 3.示例代码 前言 这篇文章介绍下C中的模版,包括函数模版和类模版。 1.函数模版 在编程的过程中,编写函数都会考虑将其写成模版…...
19、差分矩阵
差分矩阵 题目描述 输入一个n行m列的整数矩阵,再输入q个操作,每个操作包含五个整数x1, y1, x2, y2, c,其中(x1, y1)和(x2, y2)表示一个子矩阵的左上角坐标和右下角坐标。 每个操作都要将选中的子矩阵中的每个元素的值加上c。 请你将进行完…...
wordpress外贸独立站模板
wordpress外贸独立站模板 WordPress Direct Trade 外贸网站模板,适合做跨境电商的外贸公司官方网站使用。 https://www.waimaoyes.com/wangzhan/22.html...
HTTP/1.0、HTTP/1.1、HTTP/2.0、HTTP3.0的区别
一、HTTP/1.0 1996年5月,HTTP/1.0版本发布,为了提高系统的效率,HTTP/1.0规定浏览器与服务器只保持短暂的连接,浏览器的每次请求都需要与服务器建立一个TCP连接,服务器完成请求处理后立即断开TCP连接,服务器…...
聚合DNS管理系统v1.0全新发布 域名解析管理系统
内容目录 一、详细介绍二、效果展示1.部分代码2.效果图展示 三、学习资料下载 一、详细介绍 聚合DNS管理系统可以实现在一个网站内管理多个平台的域名解析,目前已支持的域名平台有:阿里云、腾讯云、华为云、西部数码、CloudFlare。本系统支持多用户&…...
LabVIEW厂房漏水检测监控系统
LabVIEW厂房漏水检测监控系统 随着信息技术和智能制造的快速发展,对于精密仪器和重要物品存放场所的环境监控日益重要,特别是防止漏水带来的潜在风险。漏水不仅可能导致珍贵资料或仪器的损坏,还可能引发安全事故,给企业和研究机构…...
(3)(3.1) 英特尔Realsense深度摄像头(二)
文章目录 前言 5 配置ArduPilot 6 地面测试:飞行前验证 7 飞行测试 8 实验 9 数据闪存记录 前言 本文介绍如何将英特尔 Realsense 深度摄像头(Intel Realsense Depth Camera)与 ArduPilot 配合使用,以实现避障(obstacle avoidance)。该方法使用在…...
go interface{} 作为函数参数
在 Go 中,将 interface{} 作为函数参数的意义在于使函数接受任意类型的参数。这种参数类型称为空接口,因为它不限制参数的具体类型,可以接受任何类型的值。 使用空接口作为函数参数具有以下几个意义: 通用性: 空接口允…...
Django之REST Client插件
一、接口测试工具介绍 在开发前后端分离项目时,无论是开发后端,还是前端,基本都是需要测试API接口的内容,而目前我们需要开发遵循RESTFul规范的项目,也是必然的(自己不开发前端页面)。 在网上有很多这样的工具,常用的postman,但还是需要下载安装。在这我们介绍一个VSCod…...
java实现UDP数据交互
1、回显服务器 服务器端 import java.io.IOException; import java.net.DatagramPacket; import java.net.DatagramSocket; import java.net.SocketException;public class UDP_Server {private DatagramSocket socketnull;public UDP_Server(int port) throws SocketExcepti…...
护眼台灯怎么选看哪些指标?不踩雷护眼台灯十大排名
平常经常面对电子屏幕的上班族、学业负担重的学生族用眼时间都比较长,再加上不健康的用眼习惯,近视人数不断增多。而在这当中,健康的光线也十分重要,良好的光线能够让眼睛更加舒服,用眼负担也会减轻不少,因…...
Web API(六)之正则表达式
Web API(六)之正则表达式 正则表达式正则基本使用元字符边界符量词范围字符类替换和修饰符change 事件判断是否有类正则表达式 正则表达式(Regular Expression)是一种字符串匹配的模式(规则) 使用场景: 例如验证表单:手机号表单要求用户只能输入11位的数字 (匹配)过滤…...
304. 前缀和技巧中的边界值处理
文章目录 题目问题反思 题目 题目如下,其实并不难,属于小而美的前缀和技巧中的体型。因为我之前做过这道题,所以重刷也马上就能写。但是对比我写的和之前看别人写的,明显我的代码不够简洁,一个核心的差异在于对DP数组…...
ios swift5 “Sign in with Apple“(使用苹果登录)怎样接入(第三方登录)集成AppleID登录
文章目录 截图1.在开发者网站的app id中添加Sign in with Apple功能2.在Xcode中添加Sign in with Apple功能3.代码:只有第一次登录的时候可以获取到用户名参考博客chatGPT答案 截图 1.在开发者网站的app id中添加Sign in with Apple功能 1.1 如果你新建app id,记得在…...
时间系列预测总结
转载自:https://mp.weixin.qq.com/s/B1eh4IcHTnEdv2y0l4MCog 拥有一种可靠的方法来预测和预测未来事件一直是人类的愿望。在数字时代,我们拥有丰富的信息,尤其是时间序列数据。 时间序列是指基于时间刻度维度(天、月、年等&…...
NineData创始人CEO叶正盛受邀参加『数据技术嘉年华』的技术大会
4月13日,NineData 创始人&CEO叶正盛受邀参加第13届『数据技术嘉年华』的技术大会。将和数据领域的技术爱好者一起相聚,并分享《NineData在10000公里跨云数据库间实时数据复制技术原理与实践》主题内容。 分享嘉宾 叶正盛,NineData CEO …...
nginx访问路径映射资源目录
Nginx映射资源目录是指在Nginx配置文件中设定规则,使得当客户端向Nginx服务器发送请求访问某个URL时,Nginx能够将该URL映射到服务器本地的实际文件目录,从而正确地提供该目录下的静态资源(如HTML、CSS、JavaScript、图片、视频等文…...
数据挖掘|序列模式挖掘及其算法的python实现
数据挖掘|序列模式挖掘及其算法的python实现 1. 序列模式挖掘2. 基本概念3. 序列模式挖掘实例4. 类Apriori算法(GSP算法)4.1 算法思想4.2 算法步骤4.3 基于Python的算法实现 1. 序列模式挖掘 序列(sequence)模式挖掘也称为序列分析。 序列模式发现&…...
3. Django 初探路由
3. 初探路由 一个完整的路由包含: 路由地址, 视图函数(或者视图类), 可选变量和路由命名. 本章讲述Django的路由编写规则与使用方法, 内容分为: 路由定义规则, 命名空间与路由命名, 路由的使用方式.3.1 路由定义规则 路由称为URL (Uniform Resource Locator, 统一资源定位符)…...
论文笔记:Large Language Models as Analogical Reasoners
iclr 2024 reviewer打分5558 1 intro 基于CoT prompt的大模型能够更好地解决复杂推理问题 然而传统CoT需要提供相关的例子作为指导,这就增加了人工标注的成本——>Zero-shot CoT避免了人工标注来引导推理 但是对于一些复杂的任务难以完成推理,例如c…...
(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)
题目:3442. 奇偶频次间的最大差值 I 思路 :哈希,时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况,哈希表这里用数组即可实现。 C版本: class Solution { public:int maxDifference(string s) {int a[26]…...
地震勘探——干扰波识别、井中地震时距曲线特点
目录 干扰波识别反射波地震勘探的干扰波 井中地震时距曲线特点 干扰波识别 有效波:可以用来解决所提出的地质任务的波;干扰波:所有妨碍辨认、追踪有效波的其他波。 地震勘探中,有效波和干扰波是相对的。例如,在反射波…...
【Oracle APEX开发小技巧12】
有如下需求: 有一个问题反馈页面,要实现在apex页面展示能直观看到反馈时间超过7天未处理的数据,方便管理员及时处理反馈。 我的方法:直接将逻辑写在SQL中,这样可以直接在页面展示 完整代码: SELECTSF.FE…...
VB.net复制Ntag213卡写入UID
本示例使用的发卡器:https://item.taobao.com/item.htm?ftt&id615391857885 一、读取旧Ntag卡的UID和数据 Private Sub Button15_Click(sender As Object, e As EventArgs) Handles Button15.Click轻松读卡技术支持:网站:Dim i, j As IntegerDim cardidhex, …...
【力扣数据库知识手册笔记】索引
索引 索引的优缺点 优点1. 通过创建唯一性索引,可以保证数据库表中每一行数据的唯一性。2. 可以加快数据的检索速度(创建索引的主要原因)。3. 可以加速表和表之间的连接,实现数据的参考完整性。4. 可以在查询过程中,…...
linux arm系统烧录
1、打开瑞芯微程序 2、按住linux arm 的 recover按键 插入电源 3、当瑞芯微检测到有设备 4、松开recover按键 5、选择升级固件 6、点击固件选择本地刷机的linux arm 镜像 7、点击升级 (忘了有没有这步了 估计有) 刷机程序 和 镜像 就不提供了。要刷的时…...
学习STC51单片机32(芯片为STC89C52RCRC)OLED显示屏2
每日一言 今天的每一份坚持,都是在为未来积攒底气。 案例:OLED显示一个A 这边观察到一个点,怎么雪花了就是都是乱七八糟的占满了屏幕。。 解释 : 如果代码里信号切换太快(比如 SDA 刚变,SCL 立刻变&#…...
免费PDF转图片工具
免费PDF转图片工具 一款简单易用的PDF转图片工具,可以将PDF文件快速转换为高质量PNG图片。无需安装复杂的软件,也不需要在线上传文件,保护您的隐私。 工具截图 主要特点 🚀 快速转换:本地转换,无需等待上…...
Java数值运算常见陷阱与规避方法
整数除法中的舍入问题 问题现象 当开发者预期进行浮点除法却误用整数除法时,会出现小数部分被截断的情况。典型错误模式如下: void process(int value) {double half = value / 2; // 整数除法导致截断// 使用half变量 }此时...
搭建DNS域名解析服务器(正向解析资源文件)
正向解析资源文件 1)准备工作 服务端及客户端都关闭安全软件 [rootlocalhost ~]# systemctl stop firewalld [rootlocalhost ~]# setenforce 0 2)服务端安装软件:bind 1.配置yum源 [rootlocalhost ~]# cat /etc/yum.repos.d/base.repo [Base…...
