STL1-函数模板
?1、函數(shù)模板和普通函數(shù)區(qū)別
//普通函數(shù)可以進(jìn)行自動(dòng)類(lèi)型轉(zhuǎn)換, //函數(shù)模板必須精確類(lèi)型匹配; //函數(shù)模板可以被重載;c++優(yōu)先考慮普通函數(shù);#include<iostream> using namespace std; //函數(shù)模板-->產(chǎn)生模板函數(shù)-->調(diào)用函數(shù) template<class T> T MyAdd(T a, T b) {cout << "調(diào)用函數(shù)模板" << endl;return a + b; } void MyAdd(int a, int b) {cout << "調(diào)用函數(shù)" << endl; } int main() {int a = 10, b = 20;MyAdd(a, b); double da = 1.12, db = 1.14;MyAdd(da, db); MyAdd(2, 'A');return 0; }運(yùn)行結(jié)果:?
2、函數(shù)模板機(jī)制
?
#include<iostream> using namespace std; //函數(shù)模板-->產(chǎn)生模板函數(shù)-->調(diào)用函數(shù) template<class T> T MyAdd(T a, T b) {return a + b; } int main() {int a = 10, b = 20;MyAdd(a, b); //產(chǎn)生MyAdd(int a,int b)函數(shù)并調(diào)用double da = 1.12, db = 1.14;MyAdd(da,db); //產(chǎn)生MyAdd(double a,double b)函數(shù)并調(diào)用MyAdd(a, a); //直接調(diào)用第一次產(chǎn)生的MyAdd(int a,int b)函數(shù)return 0; }3、函數(shù)模板應(yīng)用-int類(lèi)型和char類(lèi)型排序
?
#include<iostream> using namespace std; //對(duì)char類(lèi)型和Int類(lèi)型數(shù)組進(jìn)行排序 //void PrintArray(int *arr, int len) //{ // for (int i = 0; i < len; i++) // { // cout << arr[i] << " "; // } // cout << endl; //} template<class T> void PrintArray(T *arr, int len) {for (int i = 0; i < len; i++){cout << arr[i] << " ";}cout << endl; } void MySwap(int &a, int &b) {int temp = a;a = b;b = temp; }//冒泡排序 void MySort(int* arr, int len) {for (int i = 0; i < len; i++){for (int j = 0 ;j < len-i-1; j++){if (arr[j] < arr[j+1])MySwap(arr[j], arr[j+1]);}} } //選擇排序 //void MySort1(int* arr, int len) //{ // for (int i = 0; i < len; i++) // { // for (int j = i+1; j < len; j++) // { // if (arr[i] < arr[j]) // { // int temp = arr[i]; // arr[i] = arr[j]; // arr[j] = temp; // } // } // } //} template<class T> void MySort1(T* arr, int len) {for (int i = 0; i < len; i++){for (int j = i + 1; j < len; j++){if (arr[i] < arr[j]){T temp = arr[i];arr[i] = arr[j];arr[j] = temp;}}} } int main(void) {//數(shù)組int arr[] = { 2,6,1,8,9,2 };//數(shù)組長(zhǎng)度int len = sizeof(arr) / sizeof(int);cout << "排序前:";PrintArray(arr, len);MySort1(arr, len);cout << "排序后:";PrintArray(arr, len);char chArr[] = { 'a','c','f','b','e' };int lench = sizeof(chArr) / sizeof(char); cout << "排序前:";PrintArray(chArr, lench); MySort1(chArr, lench);cout << "排序后:";PrintArray(chArr, lench);return 0; }總結(jié)
- 上一篇: 什么是python标识符_Python:
- 下一篇: github搜索技巧_和逛知乎、刷微博一