在c++中,模板是实现泛型编程的核心机制,允许开发者编写与类型无关的代码。以下是函数模板和类模板的详细介绍及实际示例。
一、函数模板
定义
函数模板通过参数化类型实现泛型操作,只需编写一次代码即可处理多种数据类型,避免重复。
语法
template<typename t> 返回类型 函数名(参数列表) { ... }
typename t
表示类型占位符,编译时根据实参类型自动实例化。
真实示例
交换两个值(swap
)
template<typename t> void swap(t &a, t &b) { t temp = a; a = b; b = temp; }
使用场景:交换任意类型的变量(如 int
、string
)。
int x = 1, y = 2; swap(x, y); // 自动推导为 swap<int>
求最大值(max
)
template<typename t> t max(const t &a, const t &b) { return (a > b) ? a : b; }
使用场景:比较同类型值的最大值,要求类型支持 operator>
。
打印数组
int nums[] = {1, 2, 3}; printarray(nums); // 推导 t=int, n=3
二、类模板
定义
类模板允许创建可处理多种数据类型的类,成员变量和函数均可使用模板参数。
语法
template<typename t> class 类名 { // 类成员使用 t 作为类型 };
真实示例
动态数组(array
)
template<typename t> class array { private: t* data; size_t size; public: array(size_t size) : size(size), data(new t[size]) {} ~array() { delete[] data; } t& operator[](size_t index) { return data[index]; } size_t getsize() const { return size; } };
使用场景:存储任意类型的动态数组。
array<int> intarr(10); // 存储 int 的数组 array<string> strarr(5); // 存储 string 的数组
键值对(pair
)
template<typename t1, typename t2> class pair { public: t1 first; t2 second; pair(const t1 &f, const t2 &s) : first(f), second(s) {} };
使用场景:组合两个不同类型的数据(如字典条目)。
pair<string, int> student("alice", 90); // 姓名和分数
栈(stack
)
template<typename t> class stack { private: std::vector<t> elements; public: void push(const t &elem) { elements.push_back(elem); } t pop() { if (elements.empty()) throw std::out_of_range("stack is empty!"); t elem = elements.back(); elements.pop_back(); return elem; } };
使用场景:实现泛型栈结构,支持多种数据类型。
stack<double> doublestack; doublestack.push(3.14);
三、关键区别
特性 | 函数模板 | 类模板 |
---|---|---|
类型推导 | 自动推导参数类型(无需显式指定) | 必须显式指定类型(如 stack<int> ) |
默认模板参数 | 支持(c++11起) | 支持(如 template<typename t = int> ) |
典型应用 | 算法(如排序、交换) | 容器(如数组、栈、队列) |
四、注意事项
- 编译方式:模板代码通常放在头文件中,因为编译器需在编译时生成具体类型的实例化代码。
- 类型约束:模板中的操作(如
operator>
)需在类型t
中定义,否则编译失败。 - 性能:模板在编译时展开,无运行时开销,但可能增加代码体积。
通过合理使用模板,可以大幅提升代码复用性,同时保持类型安全和高性能。例如,标准模板库(stl)中的 vector
、sort
均基于模板实现。
到此这篇关于c++中函数模板与类模板的简单使用的文章就介绍到这了,更多相关c++函数模板与类模板内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论