【C++基础】 类模板
生活随笔
收集整理的這篇文章主要介紹了
【C++基础】 类模板
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
類模板
模板是將類中某些類型變?yōu)榉盒?#xff0c;從而定義一個(gè)模板。
如下:
類模板的語法
直接進(jìn)行對比:
| 泛型化之前 | 泛型化之后 |
類模板的實(shí)例化
注意:只要是對類模版進(jìn)行實(shí)例化,編譯器就會生成一個(gè)類!!!
顯式實(shí)例化:
隱式實(shí)例化:
生成一個(gè)處理char類型的對象:
code附錄
泛型化之前的:
#pragma once//編寫StackOfIntegers類 class Stack { private:int elements[100];int size{ 0 }; public:bool empty();int peek();int push(int value);int pop();int getSize();Stack(); }; Stack::Stack() {size = 0;for (int& i : elements) {i = 0;} }bool Stack::empty() {return (size == 0 ? true : false); }int Stack::getSize() {return size; }int Stack::peek() {return elements[size - 1]; }int Stack::pop() {int temp = elements[size - 1];elements[size - 1] = 0;size--;return temp; }int Stack::push(int value) {elements[size] = value;size++;return value; }泛型化之后的:
#pragma once//泛型化 template <typename T> //編寫StackOfIntegers類 class Stack { private:T elements[100];int size{ 0 }; public:bool empty();T peek();T push(T value);T pop();int getSize();Stack(); }; template <typename T> Stack<T>::Stack() {size = 0;for (auto & i : elements) {i = 0;} } template <typename T> bool Stack<T>::empty() {return (size == 0 ? true : false); } template <typename T> int Stack<T>::getSize() {return size; } template <typename T> T Stack<T>::peek() {return elements[size - 1]; } template <typename T> T Stack<T>::pop() {T temp = elements[size - 1];elements[size - 1] = 0;size--;return temp; } template <typename T> T Stack<T>::push(T value) {elements[size] = value;size++;return value; }main測試代碼
#include "Stack.h" #include <iostream> #include <string> int main() {Stack<char> c;std::string s{ "Hello World!"};for (auto i : s) {c.push(i);}while (c.empty() != true) {std::cout << c.pop() << std::endl;} }總結(jié)
以上是生活随笔為你收集整理的【C++基础】 类模板的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 长安cx20多少钱啊?
- 下一篇: 【C++基础】模板参数与模板继承