博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
c++ template归纳学习5
阅读量:7193 次
发布时间:2019-06-29

本文共 4126 字,大约阅读时间需要 13 分钟。

双重模板参数:

我们还是以前几篇中的Stack为例子i:代码如下:

template 
class CONT = std::deque > class Stack { private: CONT
elems; // elements public: void push(T const&); // push element void pop(); // pop element T top() const; // return top element bool empty() const { // return whether the stack is empty return elems.empty(); } };
在这段代码中,我们的第二个模板参数修改为:template <typename ELEM> class CONT

和往常一样,你可以使用class替代typename,但是CONT必须是class。

template 
class CONT = std::deque> // OK class Stack { … }; but the following is not:template
typename CONT = std::deque> class Stack { // ERROR … };

由于上面例子中的ELEM实际中没有用到,其实是可以省略的。

我们实现一个成员函数看看:

template 
class CONT> void Stack
::push (T const& elem) { elems.push_back(elem); // append copy of passed elem }

但是如果试图使用上面的stack,编译器会说deque不符合CONT的要求,问题在于,std中的deque要求不只是一个参数,第二个参数是一个配置器,他虽然有预设值,但是当它被用来匹配CONT参数的时候,预设值被编译器忽略了。

对于这个问题,我们可以修改,使得CONT参数要求一个带两个参数的容器。

template 
> class CONT = std::deque> class Stack { private: CONT
elems; // elements … };
最终版本如下:

// basics/stack8.hpp #ifndef STACK_HPP #define STACK_HPP #include 
#include
#include
template
> class CONT = std::deque> class Stack { private: CONT
elems; // elements public: void push(T const&); // push element void pop(); // pop element T top() const; // return top element bool empty() const { // return whether the stack is empty return elems.empty(); } // assign stack of elements of type T2 template
>class CONT2> Stack
& operator= (Stack
const&); }; template
class CONT> void Stack
::push (T const& elem) { elems.push_back(elem); // append copy of passed elem } template
class CONT> void Stack
::pop () { if (elems.empty()) { throw std::out_of_range("Stack<>::pop(): empty stack"); } elems.pop_back(); // remove last element } template
class CONT> T Stack
::top () const { if (elems.empty()) { throw std::out_of_range("Stack<>::top(): empty stack"); } return elems.back(); // return copy of last element } template
class CONT> template
class CONT2> Stack
& Stack
::operator= (Stack
const& op2) { if ((void*)this == (void*)&op2) { // assignment to itself? return *this; } Stack
tmp(op2); // create a copy of the assigned stack elems.clear(); // remove existing elements while (!tmp.empty()) { // copy all elements elems.push_front(tmp.top()); tmp.pop(); } return *this; } #endif // STACK_HPP
测试如下:

// basics/stack8test.cpp #include 
#include
#include
#include
#include "stack8.hpp" int main() { try { Stack
intStack; // stack of ints Stack
floatStack; // stack of floats // manipulate int stack intStack.push(42); intStack.push(7); // manipulate float stack floatStack.push(7.7); // assign stacks of different type floatStack = intStack; // print float stack std::cout << floatStack.top() << std::endl; floatStack.pop(); std::cout << floatStack.top() << std::endl; floatStack.pop(); std::cout << floatStack.top() << std::endl; floatStack.pop(); } catch (std::exception const& ex) { std::cerr << "Exception: " << ex.what() << std::endl; } // stack for ints using a vector as an internal container Stack
vStack; … vStack.push(42); vStack.push(7); std::cout << vStack.top() << std::endl; vStack.pop(); }
程序的输出为:

7 42 Exception: Stack<>::top(): empty stack 7

==============================================================================
本文转自被遗忘的博客园博客,原文链接:http://www.cnblogs.com/rollenholt/archive/2012/03/08/2384921.html,如需转载请自行联系原作者
你可能感兴趣的文章
python 系统设置
查看>>
北京汽车官网经销商信息抓取(解析html标签)
查看>>
mysql学习之路五(转)
查看>>
Beyond Compare比较表格小技巧
查看>>
第2章 理解面向对象
查看>>
数组的声明和遍历
查看>>
Mouse Key Hook
查看>>
Scrapy框架基础使用
查看>>
python学习笔记-(一)初识python
查看>>
前端的事件流以及事件处理程序
查看>>
react中create-react-app详情配置文档
查看>>
TLD单目标跟踪算法程序详解--OpenTLD Code 详解
查看>>
PDO基础知识
查看>>
汉诺塔问题(C++版)
查看>>
Basler和Matrox的配置及调试
查看>>
VirtualBOX 不能mount优盘,移动硬盘解决方案
查看>>
漫画:全面理解java.lang.IllegalArgumentException及其可用性设计
查看>>
[解题报告] 100 - The 3n + 1 problem
查看>>
SpringMVC HelloWorld实例开发及部署
查看>>
从最小割角度解决最大权闭合图问题及其在二分图形式下的优化
查看>>