轉自 http://blog.sina.com.cn/s/blog_6d30debd0100sx16.html
頭文件(.h):
寫類的聲明(包括類裏面的成員和方法的聲明)、函數原型、#define常數等,但一般來說不寫出具體的實現。
在寫頭文件時需要注意,在開頭和結尾處必須按照如下樣式加上預編譯語句(如下):
#define CIRCLE_H
//你的代碼寫在這裏
#endif
這樣做是爲了防止重複編譯,不這樣做就有可能出錯。
至於CIRCLE_H這個名字實際上是無所謂的,你叫什麼都行,只要符合規範都行。原則上來說,非常建議把它寫成這種形式,因爲比較容易和頭文件的名字對應。
源文件(.cpp):
源文件主要寫實現頭文件中已經聲明的那些函數的具體代碼。需要注意的是,開頭必須#include一下實現的頭文件,以及要用到的頭文件。那麼當你需要用到自己寫的頭文件中的類時,只需要#include進來就行了。
下面舉個最簡單的例子來描述一下,咱就求個圓面積。
第1步,建立一個空工程(以在VS2003環境下爲例)。
第2步,在頭文件的文件夾裏新建一個名爲Circle.h的頭文件,它的內容如下:
#define CIRCLE_H
class Circle
{
private:
double r;//半徑
public:
Circle();//構造函數
Circle(double R);//構造函數
double Area();//求面積函數
};
#endif
注意到開頭結尾的預編譯語句。在頭文件裏,並不寫出函數的具體實現。
第3步,要給出Circle類的具體實現,因此,在源文件夾裏新建一個Circle.cpp的文件,它的內容如下:
Circle::Circle()
{
this->r=5.0;
}
Circle::Circle(double R)
{
this->r=R;
}
double Circle:: Area()
{
return 3.14*r*r;
}
需要注意的是:開頭處包含了Circle.h,事實上,只要此cpp文件用到的文件,都要包含進來!這個文件的名字其實不一定要叫Circle.cpp,但非常建議cpp文件與頭文件相對應。
最後,我們建一個main.cpp來測試我們寫的Circle類,它的內容如下:
#include "Circle.h"
using namespace std;
int main()
{
Circle c(3);
cout<<"Area="<<c.Area()<<endl;
return 1;
}
注意到開頭時有#include "Circle.h"的聲明,證明我們使用到了我們剛纔寫的Circle類。
至此,我們工程的結構爲:
運行一下,輸出結果爲:
說明我們寫的Circle類確實可以用了。