【C++深度剖析教程39】实现C++数组类模板
生活随笔
收集整理的這篇文章主要介紹了
【C++深度剖析教程39】实现C++数组类模板
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
上一篇文章在那個學習了多參數類模板與特化的分析:點擊鏈接查看上一篇文章:類模板深度剖析
本篇文章學習記錄:
- 數值型模板參數
- 實現C++數組類模板
1、模板中的數值型參數
模板參數可以是數值型參數。也就是非類型參數。如下圖所示:
我們可以像上面定義一個局部數組,但是卻不能這樣定義:
int n=10; func<double,n>();上面這種寫法就是錯的!!!
實際上,不光是類型參數不能為數值型模板參數,下面幾種情況也不能作為模板參數
- 浮點數不能作為模板參數
- 變量不能作為模板參數(上面的int n)
- 類對象不能作為模板參數
實際上,數值型模板參數是必須在編譯階段被處理的單元,因此在編譯階段數值型模板參數必須被準確無誤的確定。向上面的變量,類對象等,都是只有在運行的時候才能夠被確定的,所以不能作為數值型模板的參數。
2、實現C++中的數組類模板
以下使用C++的模板技術,實現一個通用的數組類。并給出創建的實例。從而更加深刻的理解模板技術。(具體代碼比較簡單就不分析了,主要理解使用模板技術編寫一些通用的類如何實現。)
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系統上對上述程序進行編譯并運行得出結果如下圖:
很明顯,我們的數組類模板實現的很成功。
本文參考狄泰軟件學院相關課程
想學習的可以加狄泰軟件學院群,
群聊號碼:199546072
學習探討加個人(可以免費幫忙下載CSDN資源):
qq:1126137994
微信:liu1126137994
總結
以上是生活随笔為你收集整理的【C++深度剖析教程39】实现C++数组类模板的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: MAPLAP开发环境中release模式
- 下一篇: 【剑指offer - C++/Java】