c和c++的某些小區別
C++類型檢查更加嚴格
c語言中,當字符當做函數參數傳入是,都把字符當整型int使用,sizeof('c') = sizeof(int); 更進一步,c編譯器把字符常量等同於整數常量處理: putchar(10) 同 putchar('\n') 等效。
但是,C++中, sizeof('c') == 1, 補充說明一點, sizeof(wchar_t) ==4。 因此可以很容易代表65,536個不同的Unicode字符。 另外,C++中,區別函數不僅要看他的函數名,更要看它的參數。因此,putchar(10)調用的是putchar(int)版本,putchar('\n')調用的是putchar(char)版本。
C++的函數原型檢查更加嚴格。如c中的函數定義: void func();表示函數func()存在,無返回值。該聲明不指定具體有多少個形式參數。但是在C++中,表示其不得有形式參數傳入!
main函數
C++中, main函數主要有兩種寫法: int main() 和 int main(int argc, char** argv);
main函數中的返回類型為 int, 不是void
若無顯示寫 return語句,默認返回0;
若寫了return語句,必須跟上某個整型值,如 return 1; 只寫 return; 是嚴重錯誤的。
類型檢查
函數調用時,原型必須嚴格匹配。,但是C++不默認包含,因此必須包含 cstdio 頭文件。C語言中某些編譯器友情贊助了stdio.h。
函數相關的不同
函數重載
C++支持函數重載。函數重載必須滿足
a. 函數名相同
b. 形參表不同
c. 形參的屬性不同 即是否 const
在編譯時,其實對重載函數,內部采用另外個名字表達,專業術語是"name mangling", 如 void show(int) -->
VshowI, void show(char*)-->VshowCP, 這樣的名字。
形參默認值
默認形參必須出現在函數定義中,而不是在函數實現中。
代碼更加優雅
C++11 中的 NULL-pointers vs. 0-pointers and nullptr
C++中所有的零值都是0. 在C中,NULL在指針上下文中表示0,在C++中,應該避免使用NULL,雖然它的宏定義就是0.
C++11引入了新的關鍵字nullptr表示零值指針,它只能賦給指針類型
C++中可以使用C運行庫中的函數,但是需要加上 extern "C" 這個前綴
在C89中,局部變量必須在函數或語句塊的起始處定義!還在使用VC6.0的請注意了,為了你更好的代碼生涯,拋棄它吧。 C99已經支持局部定義了,算是C的一大改進。 而C++可以在任意地方定義局部變量。
C++中,結構體在定義變量時可以省略struct關鍵字
C++中,結構體中可以包含函數,即默認屬性是public的類