C++模板初阶

简介: C++模板初阶

文章目录

引子

我们以前对于交换两个变量可能会根据其参数类型的不同写不同的函数,但是每个函数除去参数类型之外都是相同的

//交换两个变量
//c语言交换
void swapint(int *a,int *b)
{}
//c++
//c++可以重载
void swap(int & a,int& b)
{}
void swap(double& a,double&b)
{}

因此就造成了很大的冗余没有必要,所以就提出了模板的概念

模板

函数模板模板和印刷术非常像 普通情况下,如,要抄一首诗,1000编,让1000个人来抄,效率很低

我们就可以把诗词刻在一个模具上面,印刷出来1000份,非常的方便

template < class T>

也可以template < class T1,class T2……>

//函数模板
template<class T>//也可以这样template<typename T>,模板参数列表--参数的类型
//也可以定义多个类型
//template<class T1,class T2>
//无论有多少个函数类型,都用他就可以了,自定义类型也可以
void swap(T& a, T& b)//函数参数列表,参数对象,
{
  T x = a;
  a = b;
  b = x;
}
int main()
{
  int a = 0, b = 1;
  double c = 1.1, d = 2.0;
  //我们写函数交换
  swap(a, b);//调用的是实例化之后的函数,模板实例化 swap(d, c);
  char e = ' ', f = 'a';
  //很麻烦都是类似的,这些swap最大的不同再类型上面,只是单纯的类型不一样其他东西都是一样的,
  return 0;
}
template<class t>
t add(const t& a, const t& b)
{
  return a + b;
}
template<class T1,class T2,class T3>
T1 add(const T2& a, const T3& b)
{
  return a + b;
}
int main()
{
  int a = 1, b = 2;
  double c = 1.1, d = 2.3;
  cout << add(a, b) << endl;
  cout << add(c, d) << endl;
  //如果要对于a和d加,不可以直接弄
  //1.强制转
cout<<add((double)a, d)<<endl;//这些都是自己推
//2.显示实例化
cout << add<int>(a, d) << endl;//指定我们要实例化的类型,指定t用int类型
cout << add<double>(a, d) << endl;
cout << add(c, d) << endl;
  return 0;
}

类模板

//类的模板,语法也是类似的
template<class t1>
class Stack
{
private:
  int _top; 
  int _capacity;
  t1 * _a;
public:
  Stack(int capacity = 4)
    :_top(0)
    , _capacity(4)
  {
    _a = new t1[capacity];//对于*a的处理初始化非常方便
  }
  ~Stack()
  {
    delete[] _a;
    _a = nullptr;
  }
  void Push(const t1& m);
};
template<class t1>
void Stack<t1>::Push(const t1& m)//要指定类模板
{
}
int main()
{
  //类模板不支持参数类型的推演,只支持显示实例化的指定
  Stack<int> st1(2);//存int
  Stack <double>st2(2);//存double
  Stack<int*>st3;
  Stack<char>st4;
  st1.Push(1);
  return 0;
}
相关文章
|
2月前
|
缓存 算法 程序员
C++STL底层原理:探秘标准模板库的内部机制
🌟蒋星熠Jaxonic带你深入STL底层:从容器内存管理到红黑树、哈希表,剖析迭代器、算法与分配器核心机制,揭秘C++标准库的高效设计哲学与性能优化实践。
C++STL底层原理:探秘标准模板库的内部机制
|
6月前
|
存储 算法 安全
c++模板进阶操作——非类型模板参数、模板的特化以及模板的分离编译
在 C++ 中,仿函数(Functor)是指重载了函数调用运算符()的对象。仿函数可以像普通函数一样被调用,但它们实际上是对象,可以携带状态并具有更多功能。与普通函数相比,仿函数具有更强的灵活性和可扩展性。仿函数通常通过定义一个包含operator()的类来实现。public:// 重载函数调用运算符Add add;// 创建 Add 类的对象// 使用仿函数return 0;
241 0
|
6月前
|
人工智能 机器人 编译器
c++模板初阶----函数模板与类模板
class 类模板名private://类内成员声明class Apublic:A(T val):a(val){}private:T a;return 0;运行结果:注意:类模板中的成员函数若是放在类外定义时,需要加模板参数列表。return 0;
191 0
|
9月前
|
编译器 C++
模板(C++)
本内容主要讲解了C++中的函数模板与类模板。函数模板是一个与类型无关的函数家族,使用时根据实参类型生成特定版本,其定义可用`typename`或`class`作为关键字。函数模板实例化分为隐式和显式,前者由编译器推导类型,后者手动指定类型。同时,非模板函数优先于同名模板函数调用,且模板函数不支持自动类型转换。类模板则通过在类名后加`&lt;&gt;`指定类型实例化,生成具体类。最后,语录鼓励大家继续努力,技术不断进步!
|
10月前
|
编译器 C++
㉿㉿㉿c++模板的初阶(通俗易懂简化版)㉿㉿㉿
㉿㉿㉿c++模板的初阶(通俗易懂简化版)㉿㉿㉿
|
10月前
|
安全 C++
【c++】模板详解(2)
本文深入探讨了C++模板的高级特性,包括非类型模板参数、模板特化和模板分离编译。通过具体代码示例,详细讲解了非类型参数的应用场景及其限制,函数模板和类模板的特化方式,以及分离编译时可能出现的链接错误及解决方案。最后总结了模板的优点如提高代码复用性和类型安全,以及缺点如增加编译时间和代码复杂度。通过本文的学习,读者可以进一步加深对C++模板的理解并灵活应用于实际编程中。
160 0
|
10月前
|
存储 安全 算法
深入理解C++模板编程:从基础到进阶
在C++编程中,模板是实现泛型编程的关键工具。模板使得代码能够适用于不同的数据类型,极大地提升了代码复用性、灵活性和可维护性。本文将深入探讨模板编程的基础知识,包括函数模板和类模板的定义、使用、以及它们的实例化和匹配规则。
|
安全 编译器 C++
【C++11】可变模板参数详解
本文详细介绍了C++11引入的可变模板参数,这是一种允许模板接受任意数量和类型参数的强大工具。文章从基本概念入手,讲解了可变模板参数的语法、参数包的展开方法,以及如何结合递归调用、折叠表达式等技术实现高效编程。通过具体示例,如打印任意数量参数、类型安全的`printf`替代方案等,展示了其在实际开发中的应用。最后,文章讨论了性能优化策略和常见问题,帮助读者更好地理解和使用这一高级C++特性。
400 4
|
算法 编译器 C++
【C++】模板详细讲解(含反向迭代器)
C++模板是泛型编程的核心,允许编写与类型无关的代码,提高代码复用性和灵活性。模板分为函数模板和类模板,支持隐式和显式实例化,以及特化(全特化和偏特化)。C++标准库广泛使用模板,如容器、迭代器、算法和函数对象等,以支持高效、灵活的编程。反向迭代器通过对正向迭代器的封装,实现了逆序遍历的功能。
193 3
|
编译器 C++
【c++】模板详解(1)
本文介绍了C++中的模板概念,包括函数模板和类模板,强调了模板作为泛型编程基础的重要性。函数模板允许创建类型无关的函数,类模板则能根据不同的类型生成不同的类。文章通过具体示例详细解释了模板的定义、实例化及匹配原则,帮助读者理解模板机制,为学习STL打下基础。
178 0