【C++深度剖析教程39】实现C++数组类模板
上一篇文章在那個(gè)學(xué)習(xí)了多參數(shù)類模板與特化的分析:點(diǎn)擊鏈接查看上一篇文章:類模板深度剖析
本篇文章學(xué)習(xí)記錄:
- 數(shù)值型模板參數(shù)
- 實(shí)現(xiàn)C++數(shù)組類模板
1、模板中的數(shù)值型參數(shù)
模板參數(shù)可以是數(shù)值型參數(shù)。也就是非類型參數(shù)。如下圖所示:
我們可以像上面定義一個(gè)局部數(shù)組,但是卻不能這樣定義:
int n=10; func<double,n>();上面這種寫法就是錯(cuò)的!!!
實(shí)際上,不光是類型參數(shù)不能為數(shù)值型模板參數(shù),下面幾種情況也不能作為模板參數(shù)
- 浮點(diǎn)數(shù)不能作為模板參數(shù)
- 變量不能作為模板參數(shù)(上面的int n)
- 類對(duì)象不能作為模板參數(shù)
實(shí)際上,數(shù)值型模板參數(shù)是必須在編譯階段被處理的單元,因此在編譯階段數(shù)值型模板參數(shù)必須被準(zhǔn)確無誤的確定。向上面的變量,類對(duì)象等,都是只有在運(yùn)行的時(shí)候才能夠被確定的,所以不能作為數(shù)值型模板的參數(shù)。
2、實(shí)現(xiàn)C++中的數(shù)組類模板
以下使用C++的模板技術(shù),實(shí)現(xiàn)一個(gè)通用的數(shù)組類。并給出創(chuàng)建的實(shí)例。從而更加深刻的理解模板技術(shù)。(具體代碼比較簡單就不分析了,主要理解使用模板技術(shù)編寫一些通用的類如何實(shí)現(xiàn)。)
HeapArray.h
#ifndef _HEAPARRAY_H_ #define _HEAPARRAY_H_template < typename T > class HeapArray { private:int m_length;T* m_pointer;HeapArray(int len);HeapArray(const HeapArray<T>& obj);bool construct(); public:static HeapArray<T>* NewInstance(int length); int length();bool get(int index, T& value);bool set(int index ,T value);T& operator [] (int index);T operator [] (int index) const;HeapArray<T>& self();~HeapArray(); };template < typename T > HeapArray<T>::HeapArray(int len) {m_length = len; }template < typename T > bool HeapArray<T>::construct() { m_pointer = new T[m_length];return m_pointer != NULL; }template < typename T > HeapArray<T>* HeapArray<T>::NewInstance(int length) {HeapArray<T>* ret = new HeapArray<T>(length);if( !(ret && ret->construct()) ) {delete ret;ret = 0;}return ret; }template < typename T > int HeapArray<T>::length() {return m_length; }template < typename T > bool HeapArray<T>::get(int index, T& value) {bool ret = (0 <= index) && (index < length());if( ret ){value = m_pointer[index];}return ret; }template < typename T > bool HeapArray<T>::set(int index, T value) {bool ret = (0 <= index) && (index < length());if( ret ){m_pointer[index] = value;}return ret; }template < typename T > T& HeapArray<T>::operator [] (int index) {return m_pointer[index]; }template < typename T > T HeapArray<T>::operator [] (int index) const {return m_pointer[index]; }template < typename T > HeapArray<T>& HeapArray<T>::self() {return *this; }template < typename T > HeapArray<T>::~HeapArray() {delete[]m_pointer; }#endifmain.cpp
#include <iostream> #include <string> #include "Array.h" #include "HeapArray.h"using namespace std;int main() {HeapArray<char>* pai = HeapArray<char>::NewInstance(10);if( pai != NULL ){HeapArray<char>& ai = pai->self();for(int i=0; i<ai.length(); i++){ai[i] = i + 'a';}for(int i=0; i<ai.length(); i++){cout << ai[i] << endl;}}delete pai;return 0; }在linux系統(tǒng)上對(duì)上述程序進(jìn)行編譯并運(yùn)行得出結(jié)果如下圖:
很明顯,我們的數(shù)組類模板實(shí)現(xiàn)的很成功。
本文參考狄泰軟件學(xué)院相關(guān)課程
想學(xué)習(xí)的可以加狄泰軟件學(xué)院群,
群聊號(hào)碼:199546072
學(xué)習(xí)探討加個(gè)人(可以免費(fèi)幫忙下載CSDN資源):
qq:1126137994
微信:liu1126137994
總結(jié)
以上是生活随笔為你收集整理的【C++深度剖析教程39】实现C++数组类模板的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: MAPLAP开发环境中release模式
- 下一篇: s3c2440移植MQTT