C++中有类继承的概念,意思就是能够实现与继承相同功能的一种应用。那么什么又是C++类模板呢?它是否也和类函数的用法相似呢?首先让我们通过以下这段代码来为大家详细介绍一下C++类模板的应用方式。
C++类模板代码示例:
- #include "stdafx.h"
- #include "Stack.h"
- #include < iostream>
- #include < string>
- #include < cstdlib>
- #include < stdexcept>
- int _tmain(int argc, _TCHAR* argv[])
- {
- try
- {
- Stack< int> intStack;
- Stack< std::string> stringStack;
- intStack.push(7);
- std::cout< < "intStack.top() = >"< < intStack.top()
< < std::endl;- stringStack.push("Hello!");
- std::cout< < "stringStack.top() = >"< < stringStack.top()
< < std::endl;- stringStack.pop();
- stringStack.pop();
- }
- catch(std::exception const& ex)
- {
- std::cerr< < "Exception: "< < ex.what()< < std::endl;
- return EXIT_FAILURE;
- }
- return 0;
- }
#t#在这段C++类模板的代码中,语句[Stack< int> intStack;]展示了类模板的实例化,并定义一个变量的过程。和函数模板的实例化一样,类模板的实例化也必须提供所需参数的类型。实例化后定义的变量可以和普通变量一样的调用类模板定义的成员函数。只是需要注意,对于类模板的成员函数,只有在被调用的时候才会被实例化。对于上面的intStack,由于只调用了push()成员函数,所以它只实例化了push成员函数(构造和析够函数除外,他们会被默认的调用)。
这样作有两个好处:
一是可以节约空间和时间。
二是,对于每一个类模板的参数类型,都要求提供模板所需要的操作。比如,如果你用自定义的类MyClass作为一个类模板Caculator< T>的参数。由于Caculator类模板要求提供的参数类型支持“+”和"-"操作。但是,你的MyClass类只需要用到“+”操作,没有提供"-"操作。得益于上面的规则,你的MyClass类型还是可以作为Caulator< T>的参数。前提是你没有用到"-"相关的成员函数。
以上就是我们对C++类模板的相关应用介绍。