一箇中大型軟件每每由多名程序員共同開發,會使用大量的變量和函數,不可避免地會出現變量或函數的命名衝突。當全部人的代碼都測試經過,沒有問題時,將它們結合到一塊兒就有可能會出現命名衝突。程序員
例如小李和小韓都參與了一個文件管理系統的開發,它們都定義了一個全局變量 fp,用來指明當前打開的文件,將他們的代碼整合在一塊兒編譯時,很明顯編譯器會提示 fp 重複定義(Redefinition)錯誤。函數
爲了解決合做開發時的命名衝突問題,C++ 引入了命名空間(Namespace)的概念。請看下面的例子:
namespace Li{ //小李的變量定義測試
FILE fp = NULL;
}
namespace Han{ //小韓的變量定義spa
FILE fp = NULL
}
小李與小韓各自定義了以本身姓氏爲名的命名空間,此時再將他們的 fp 變量放在一塊兒編譯就不會有任何問題。
命名空間有時也被稱爲名字空間、名稱空間。
namespace 是C++中的關鍵字,用來定義一個命名空間,語法格式爲:
namespace name{code
//variables, functions, classes
}內存
name是命名空間的名字,它裏面能夠包含變量、函數、類、typedef、#define 等,最後由{ }包圍。開發
使用變量、函數時要指明它們所在的命名空間。以上面的 fp 變量爲例,能夠這樣來使用:
Li::fp = fopen("one.txt", "r"); //使用小李定義的變量 fp
Han::fp = fopen("two.txt", "rb+"); //使用小韓定義的變量 fp
::是一個新符號,稱爲域解析操做符,在C++中用來指明要使用的命名空間。編譯器
除了直接使用域解析操做符,還能夠採用 using 關鍵字聲明,例如:
using Li::fp;
fp = fopen("one.txt", "r"); //使用小李定義的變量 fp
Han :: fp = fopen("two.txt", "rb+"); //使用小韓定義的變量 fp
在代碼的開頭用using聲明瞭 Li::fp,它的意思是,using 聲明之後的程序中若是出現了未指明命名空間的 fp,就使用 Li::fp;可是若要使用小韓定義的 fp,仍然須要 Han::fp。it
using 聲明不只能夠針對命名空間中的一個變量,也能夠用於聲明整個命名空間,例如:
using namespace Li;
fp = fopen("one.txt", "r"); //使用小李定義的變量 fp
Han::fp = fopen("two.txt", "rb+"); //使用小韓定義的變量 fp
若是命名空間 Li 中還定義了其餘的變量,那麼一樣具備 fp 變量的效果。在 using 聲明後,若是有未具體指定命名空間的變量產生了命名衝突,那麼默認採用命名空間 Li 中的變量。io
命名空間內部不只能夠聲明或定義變量,對於其它能在命名空間之外聲明或定義的名稱,一樣也都能在命名空間內部進行聲明或定義,例如類、函數、typedef、#define 等均可以出如今命名空間中。
站在編譯和連接的角度,代碼中出現的變量名、函數名、類名等都是一種符號(Symbol)。有的符號能夠指代一個內存位置,例如變量名、函數名;有的符號僅僅是一個新的名稱,例如 typedef 定義的類型別名。
下面來看一個命名空間完整示例代碼:
//將類定義在命名空間中
namespace Diy{
class Student{ public: char *name; int age; float score; public: void say(){ printf("%s的年齡是 %d,成績是 %f\n", name, age, score); } };
}
int main(){
Diy::Student stu1; stu1.name = "小明"; stu1.age = 15; stu1.score = 92.5f; stu1.say(); return 0;
}運行結果:小明的年齡是 15,成績是 92.500000