C++模板

简介: C++模板

C++模板是C++语言的一种特性,它允许程序员创建与类型无关的函数和类。通过使用模板,您可以编写一份代码,然后让编译器根据具体的数据类型来生成多个版本的函数或类。这极大地提高了代码的重用性和灵活性。

函数模板

函数模板用于定义可以接受任意数据类型的函数。在函数模板中,类型被用作参数,就像常规函数参数一样。

cpp复制代码

 

template <typename T> // 声明一个类型参数T

 

T add(T a, T b) { // 使用类型参数T定义函数

 

return a + b;

 

}

 

 

 

int main() {

 

int x = 5, y = 10;

 

double a = 1.5, b = 2.5;

 

std::cout << "x + y = " << add(x, y) << std::endl; // 调用add<int>

 

std::cout << "a + b = " << add(a, b) << std::endl; // 调用add<double>

 

return 0;

 

}

在上面的例子中,add 是一个函数模板,它可以接受任何类型 T 的两个参数,并返回它们的和。当我们在 main 函数中调用 add 时,编译器会为每种不同的类型(intdouble)生成一个特定的函数版本。

类模板

类模板用于定义可以接受任意数据类型的类。与函数模板类似,类型参数在类模板的声明中使用。

cpp复制代码

 

template <typename T> // 声明一个类型参数T

 

class Array {

 

private:

 

T* arr;

 

size_t size;

 

public:

 

Array(T arr[], size_t s);

 

void print();

 

// ... 其他成员函数 ...

 

};

 

 

 

template <typename T>

 

Array<T>::Array(T arr[], size_t s) {

 

size = s;

 

this->arr = new T[s];

 

for (size_t i = 0; i < s; i++) {

 

this->arr[i] = arr[i];

 

}

 

}

 

 

 

template <typename T>

 

void Array<T>::print() {

 

for (size_t i = 0; i < size; i++) {

 

std::cout << arr[i] << " ";

 

}

 

std::cout << std::endl;

 

}

 

 

 

int main() {

 

int intArr[] = {1, 2, 3, 4, 5};

 

Array<int> a(intArr, 5);

 

a.print(); // 输出: 1 2 3 4 5

 

 

 

double doubleArr[] = {1.1, 2.2, 3.3, 4.4};

 

Array<double> b(doubleArr, 4);

 

b.print(); // 输出: 1.1 2.2 3.3 4.4

 

 

 

return 0;

 

}

在这个例子中,Array 是一个类模板,它可以存储任何类型 T 的数组。我们在 main 函数中创建了两个 Array 对象:一个用于 int 类型,另一个用于 double 类型。编译器会为每种类型生成一个特定的类版本。

类型推导

从C++11开始,编译器能够自动推导模板参数的类型,这称为类型推导。因此,在调用函数模板或创建类模板的实例时,通常可以省略模板参数。

cpp复制代码

 

// 函数模板类型推导示例

 

int main() {

 

int sum = add(3, 4); // 类型推导为 add<int>

 

double prod = add(3.0, 4.0); // 类型推导为 add<double>

 

return 0;

 

}

 

 

 

// 类模板类型推导示例

 

int main() {

 

Array<int> a = {1, 2, 3, 4, 5}; // 显式指定类型

 

Array b = {1.1, 2.2, 3.3, 4.4}; // 类型推导为 Array<double>

 

return 0;

 

}

模板是C++中非常强大的工具,它们允许程序员创建通用和可重用的代码,而无需为每个数据类型编写特定的版本。然而,模板的使用也可能导致编译时间的增加,因为对于每种新的类型组合,编译器都需要生成新的代码。因此,在使用模板时需要权衡代码重用和编译时间。

 

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