C++ 模板程式設計是一種使用參數化類別或函數建立通用程式碼的技術,允許處理各種資料類型,提高程式碼可維護性和可擴展性。定義模板:使用 template 關鍵字指定模板參數,建立一個可透過不同類型實例化的類別或函數。使用模板:在模板名前加上 template 關鍵字並指定參數類型,建立模板的具體實例。實戰案例:使用模板進行二分查找,透過為模板參數傳遞不同的類型,可以在不同類型的排序數組上使用該函數。
揭開C++ 模板程式設計的面紗
C++ 模板程式設計是一種強大的技術,它允許您編寫通用的代碼,該代碼可以處理各種資料類型。透過使用模板,您可以建立可重複使用的元件,從而提高您的程式碼的可維護性和可擴充性。
什麼是模板?
模板是參數化的類別或函數。這意味著您可以透過為模板參數提供不同的類型來建立模板的多個實例。例如,下面的程式碼會建立一個模板類別 Array
,它可以儲存任何類型的元素。
template<typename T> class Array { public: Array(int size) : size(size), data(new T[size]) {} ~Array() { delete[] data; } T& operator[](int index) { return data[index]; } private: int size; T* data; };
如何使用模板
要使用模板,您需要在類別或函數名稱前面加上template
關鍵字,並指定模板參數。例如,要建立整數數組,您可以使用以下程式碼:
Array<int> intArray(10);
實戰案例:二分查找
讓我們看一個使用模板進行二分查找的實戰案例。二分查找是一種高效的搜尋演算法,它適用於已排序的陣列。
template<typename T> int binary_search(Array<T>& arr, T target) { int low = 0; int high = arr.size() - 1; while (low <= high) { int mid = (low + high) / 2; T guess = arr[mid]; if (guess == target) { return mid; } else if (guess < target) { low = mid + 1; } else { high = mid - 1; } } return -1; }
此函數使用模板,因此它可以處理任何類型的排序數組。要在整數陣列上使用此函數,您可以使用以下程式碼:
Array<int> intArray = {1, 3, 5, 7, 9}; int result = binary_search(intArray, 5);
以上是揭開C++模板程式設計的面紗的詳細內容。更多資訊請關注PHP中文網其他相關文章!