//普通函數 和 函數模板 區別
int myPlus(int a, int b)
{return a + b;
}template<class T>
T myPlus2(T a, T b)
{return a + b;
}void test01()
{int a = 10;int b = 20;char c = 'c';cout << myPlus(a, c) << endl; //隱式類型轉換 將 char c轉為 int類型//myPlus2(a, c); //自動類型推導方式 ,不可以進行隱式類型轉換的,但是顯示指定類型方式可以進行隱式類型轉換}//普通函數 和 函數模板 調用規則
template<class T>
void myPrint(T a, T b)
{cout << "函數模板調用" << endl;
}/*
//假設傳入T是int類型 ,生成一個 下面的函數,這個函數 稱為 模板函數
void myPrint(int a, int b)
{
cout << "函數模板調用" << endl;
}
*/
template<class T>
void myPrint(T a, T b , T c)
{cout << "函數模板調用myPrint(T a, T b , T c)" << endl;
}void myPrint(int a, int b)
{cout << "普通函數調用" << endl;
}void test02()
{//1、如果普通函數和函數模板可以同時調用,優先使用是普通函數int a = 0;int b = 0;//myPrint(a, b);//2、如果想強制調用 函數模板中的內容,可以使用空參數列表//myPrint<>(a, b);3、函數模板 可以發生函數重載//myPrint(a, b, 10);//4、如果函數模板可以產生更好的匹配,那么優先使用是函數模板char c = 'c';char d = 'd';myPrint(c, d);
}
int main(){//test01();test02();system("pause");return EXIT_SUCCESS;
}
普通函數和函數模板的區別以及調用規則 1.1 區別: a. 普通函數可以隱式類型轉換 b. 函數模板如果是自動類型推導的使用方式, 是不可以發生隱式類型轉換 如果函數模板在調用的時候顯示的指定了T的類型,是可以發生隱式類型轉換的。 比如 funcTemplate(a, b); 1.2 調用規則: a. 如果函數模板和普通函數都可以實現調用, 那么優先調用的是普通函數 b. 可以通過空參數列表語法來強制調用 函數模板 c. 函數模板也可以發生函數重載 d. 如果函數模板可以產生更好的匹配, 優先使用的是函數模板
1.int * p NULL;和*p NULL的區別
1 .int * p NULL
int *pNULL;定義一個指針變量p,其指向的內存里面保存的是int類型的數據;再定義變量p的同時把p的值設置為0x00000000, 而不是把*p的值設置為0x00000000
2.*p NULL
int i 10&am…
#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
using namespace std;template<class T>
class Base
{T m_A; //子類創建時候 必須要知道T的類型,才能給父類中的m_A分配內存
};template<class T1 , class T2>
class Son :public Base<T2…
一條語句判斷數x是否2的n次冪
return !(x & (x - 1));
求取十進制數字元素1的個數
int fun(int x) { int count 0; int i, j, k; /方法2 負數不可計算,需要改進/ while (x ! 0){ if (x & 1 1) count; x x >> 1; } /方法1/ while (x …