基本信息
直接指定標識符
std::cout<<std::hex<<3.4<<std::endl;
使用using關鍵字
加入using std::cout; using std::endl; using std::cin; 則前面語句可以寫成如下代碼:
cout << std ::hex << 3.4 << endl;
使用using namespace std
例如:
#include<......>#include<......>#include<......>using namespace std;cout << hex << 3.4 << endl;
這樣命名空間std內定義的所有
標識符都有效(曝光)。就好像它們被聲明為
全局變數一樣。那么以上語句可以如下寫:
cout << hex << 3.4 << endl; 因為標準庫非常的龐大,所以程式設計師在選擇的類的名稱或函式名時就很有可能和標準庫中的某個名字相同。所以為了避免這種情況所造成的名字衝突,就把標準庫中的一切都放在名字空間std中。但這又會帶來了一個新問題。無數原有的C++代碼都依賴於使用了多年的偽標準庫中的功能,他們都是在全局空間下的。 所以就有了<iostream>和<iostream.h>等等這樣的頭檔案,一個是為了兼容以前的C++代碼,一個是為了支持新的標準。 iostream和iostream.h,前者沒有後綴。實際上,在你的
編譯器include資料夾裡面可以看到,二者是兩個檔案。打開檔案就會發現,裡面的代碼是不一樣的。 後綴為.h的頭檔案c++標準已經明確提出不支持了,早些的實現將標準庫功能定義在全局空間裡,聲明在帶.h後綴的頭檔案里,c++標準為了和C區別開,也為了正確使用命名空間,規定頭檔案不使用後綴.h。 因 此,當使用<iostream.h>時,相當於在c中調用
庫函式,使用的是全局命名空間,也就是早期的c++實現;當使用< iostream>的時候,該頭檔案沒有定義全局命名空間,必須使用namespace std;這樣才能正確使用cout。命名空間std封裝的是標準程式庫的名稱,
簡便理解
98年以後的c++語言提供一個全局的命名空間namespace,可以避免導致全局命名衝突問題。舉一個實例,請注意以下兩個頭檔案:
//one.hchar func(char);class String{...};//somelib.hclass String{...};
如果按照上述方式
定義,那么這兩個頭檔案不可能包含在同一個程式中,因為
String類會發生衝突。