C++ 模板

模板:

        模板,即数据是灵魂,其余为肉身,正所谓有趣的灵魂万里挑一,所以想要模板变得完美,关键在于数据;其余不过是抄作业的框架。

模板函数:

        模板函数可以自动推导出你传给他的数据类型,同时也可以指定数据类型;但自定义的class在做相应的运算则需要对操作符进行重载。

#include <iostream>
#include <string>using namespace std;template <typename T1,typename T2,typename T3>T1 add(T1 a,T2 b,T3 c)
{cout<<"T1"<<endl;return a+b+c;
}int main(int argc, char const *argv[])
{int a=10;float b=8.123;short c=12;cout<<add(a,'a',c)<<endl;//自动推导cout<<add<int,short,int>(a,b,c)<<endl;//手动指定参数类型return 0;
}

        模板函数与普通函数       

                 当模板函数遇上普通函数重载时,按类型匹配高的来。

#include <iostream>
#include <string>using namespace std;template <typename T, typename T1>void myswap(T &a, T1 &b) // 自动推导出传入的数据类型
{T temp;temp = a;a = b;b = temp;cout << "模板函数" << endl;
}void myswap(int &a, int &b)
{int temp = a;a = b;b = temp;cout << "普通函数" << endl;
}
int main(int argc, char const *argv[])
{int a = 10;int b = 20;myswap(a, b);cout << "a=" << a << endl;cout << "b=" << b << endl;cout << "-------------" << endl;float c = 10.5;float d = 20.5;myswap(c, d);cout << "c=" << c << endl;cout << "d=" << d << endl;cout << "-------------" << endl;int e = 10;float f = 13.35;myswap(f, e);cout << "e=" << e << endl;cout << "f=" << f << endl;cout << "-------------" << endl;return 0;
}

   自定义数据类型给模板函数传参

         自定义的数据成为模板函数的参数时参与运算时,需要自行重载操作符,否则会报错。

#include <iostream>
using namespace std;template <class T>
bool isBig(T a, T b)
{if (a > b){return true;}else{return false;}
}// 定义用户自定义数据类型
class base
{
public:base(int v) : value(v) {}private:int value;bool friend operator>(base a, base b);
};bool operator>(base a, base b)
{return a.value > b.value;
}int main()
{// 基本的数据类型// int a = 10;// int b = 20;base a(10);base b(20);if (isBig(a, b)){cout << "a is bigger than b" << endl;}else{cout << "b is bigger than a" << endl;}
}

模板类:

        模板类构造

        必须手动指明参数类型。

#include <iostream>
#include <string>
using namespace std;template <class T, class T1, class T2>class student
{
private:T name;T1 id;T2 number;public:student(T name, T1 id, T2 number) : id(id), number(number), name(name){}void show(){cout << "name=" << name << endl;cout << "id=" << id << endl;cout << "number=" << number << endl;cout<<"---------------------------"<<endl;}
};
int main(int argc, char const *argv[])
{student<string, int, int> stu("张三", 2301956, 1346545);stu.show();student<string, string, string> tech("李四", "老师", "物理");tech.show();return 0;
}

        模板类传参

        模板是无法进行直接传参的,但可以通过特殊方式进行传参

                1、指定实例化类型

                2、将需要实例化的数据类型继续模板化

                3、直接将函数接口改为模板函数

        

#include <iostream>
using namespace std;template <class T>
class base // 定义一个模板类
{
public:T a;
};// 1.把模板类的类型 ,实例化
void set_base(base<int> &tmp, int v)
{tmp.a = v;
}void show_base(base<int> &tmp)
{cout << tmp.a << endl;
}// 2.把模板类的类型,继续模板化
template <class T>
void set_base(base<T> &tmp, T v)
{cout << "继续模板化" << endl;tmp.a = v;
}template <class T>
void show_base(base<T> &tmp)
{cout << "继续模板化" << endl;cout << tmp.a << endl;
}// 3.直接定义模板函数
template <class T, class T1>
void set_base(T &tmp, T1 v)
{tmp.a = v;
}template <class T>
void show_base(T &tmp)
{cout << tmp.a << endl;
}int main()
{base<int> tmp;set_base(tmp, 100);show_base(tmp);
}

模板类的继承

        模板类因为数据类型不确定,也无法直接继承,也需要特殊的改造;

              方法一、 指定模板数据类型,其子类回归普通类。

              方法二、将数据类型继续模板化,但其子类属性依然是模板类

#include <iostream>
using namespace std;
// 模板基类
template <class T>
class base
{
public:base() {}base(T v) : data(v) {}void show(){cout << this->data << endl;}private:T data;
};// 1.指定基类的模板类   类型  -> 已经不是模板类
class xbase : public base<int>
{
};// 2.继续把基类的类型  模板化 -> 派生类还是模板类
template <class T>
class xbase2 : public base<T>
{
};int main()
{xbase tmp;xbase2<int> tmp2;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/98323.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

学习Bootstrap 5的第四天

目录 表格 基础表格 实例 条纹表格 实例 带边框表格 实例 有悬停效果的行 实例 黑色/深色表格 实例 黑色/深色条纹表格 实例 可悬停的黑色/深色表格 实例 无边框表格 实例 上下文类 可用的上下文类&#xff1a; 实例 表头颜色 实例 小型表格 实例 响应…

大模型 Dalle2 学习三部曲(二)clip学习

clip论文比较长48页&#xff0c;但是clip模型本身又比较简单&#xff0c;效果又奇好&#xff0c;正所谓大道至简&#xff0c;我们来学习一下clip论文中的一些技巧&#xff0c;可以让我们快速加深对clip模型的理解&#xff0c;以及大模型对推荐带来革命性的变化。 clip结构 首选…

CocosCreator3.8研究笔记(五)CocosCreator 脚本说明及使用(下)

在Cocos Creator中&#xff0c;脚本代码文件分为模块和插件两种方式&#xff1a; 模块一般就是项目的脚本&#xff0c;包含项目中创建的代码、引擎模块、第三方模块。 插件脚本&#xff0c;是指从 Cocos Creator 属性检查器中导入的插件&#xff0c;一般是引入第三方引入库文件…

【从0学习Solidity】2. 值类型详解

Solidity极简入门: 2. 值类型 博主简介&#xff1a;不写代码没饭吃&#xff0c;一名全栈领域的创作者&#xff0c;专注于研究互联网产品的解决方案和技术。熟悉云原生、微服务架构&#xff0c;分享一些项目实战经验以及前沿技术的见解。关注我们的主页&#xff0c;探索全栈开发…

微服务设计和高并发实践

文章目录 1、微服务的设计原则1.1、服务拆分方法1.2、微服务的设计原则1.3、微服务架构 2、高并发系统的一些优化经验2.1、提高性能2.1.1、数据库优化2.1.2、使用缓存2.1.3、服务调用优化2.1.4、动静分离2.1.5、数据库读写分离 2.2、服务高可用2.2.1、限流和服务降级2.2.2、隔离…

亲测有效:虚拟机安装gcc,报错Could not retrieve mirrorlist http://mirrorlist.centos.org

&#xff08;网卡配置资料&#xff09; 原因&#xff1a; 网络问题 报错详情&#xff1a; One of the configured repositories failed (未知),and yum doesnt have enough cached data to continue. At this point the onlysafe thing yum can do is fail. There are a few …

Unity中Shader的UV扭曲效果的实现

文章目录 前言一、实现的思路1、在属性面板暴露一个 扭曲贴图的属性2、在片元结构体中&#xff0c;新增一个float2类型的变量&#xff0c;用于独立存储将用于扭曲的纹理的信息3、在顶点着色器中&#xff0c;根据需要使用TRANSFORM_TEX对Tilling 和 Offset 插值&#xff1b;以及…

appium自动化测试完整项目

前言 Appium是一个开源的自动化测试框架&#xff0c;支持跨平台&#xff0c;支持多种编程语言&#xff0c;可用于原生&#xff0c;混合和移动web应用程序&#xff0c;使用webdriver驱动ios&#xff0c;android应用程序、那么为了学习app自动化测试首要任务肯定就是搭建测试开发…

【【STM32-29正点原子版本串口发送传输实验】

STM32-29正点原子版本串口发送传输实验 通过串口接收或发送一个字符 例程目的 开发板上我们接入的是实现异步通信的UART接口 USB转串口原理图 我们一步步分析 PA9是串口1 的发送引脚 PA10是串口1 的接受引脚 。因为我们现在只是用到异步收发器功能&#xff0c;所以我们现…

LuatOS 开发指南

NDK 开发 官方教程 官方例程 API 下载软件 下载官方NDK例程压缩包到本地&#xff0c;并解压。可以看到目录如下&#xff1a; doc: 文档教程 env: 编译环境 example: NDK示例 platform: 需要编译的平台&#xff08;air72x/air8xx&#xff09; tools: 其他辅助软件 VSCode 使…

现代C++中的从头开始深度学习:【6/8】成本函数

现代C中的从头开始深度学习&#xff1a;成本函数 一、说明 在机器学习中&#xff0c;我们通常将问题建模为函数。因此&#xff0c;我们的大部分工作都包括寻找使用已知模型近似函数的方法。在这种情况下&#xff0c;成本函数起着核心作用。 这个故事是我们之前关于卷积的讨论的…

elmentui表单重置及出现的问题

一、表单&#xff1a; 二、代码——拿官方的代码举例(做了一些小改动)&#xff1a; 改动&#xff1a;model绑定的字段&#xff0c;由form改为queryParams ref绑定的字段form改为queryFrom 注&#xff1a;model绑定的这个字段用来做数据双向绑定的 注&#xff1a;ref绑定的这…