此句只是作为Stack class的前置申明,只是将calss名次告诉编译器,并未提供此class的任何其他信息。前置申明使得我们可以进行类指针的定义,或以此class作为数据型别:
//以下这种写法,必须先有class的前置申明才行
Stack *pt=0;
void process (const Stack&);
接下来,在定义实际的Stack class object或取用Stack的任何一个member之前,必须先定义class本身。
所有member functions 都必须在class主体内进行申明,至于是否要同时进行定义,可以自由决定。如果要在class主体内定义,这个member function会自动地被视为inline函数。
对于inline函数而言,定义与class主体内或主体外,并没有什么分别,然而就像non-member inline function一样,它也应该被置于同文件中,class定义式及其inline member function 通常都会被放在与class同名的头文件中,
例如:Stack class 的定义和其empty()函数定义都应该置于Stack.h 头文件中,此即用户想要使用Stack时应该包含的文件。
non-inline member function应该在程序代码文件中定义,该文件通常和class同名,其后接着扩展名.C,.cc,.cpp或.cxx。
将类声明和定义部分保存在头文件中
我们可以将类的声明和定义保存在一个头文件中,一般是扩展名为.h的文件,将程序执行部分也存放一个文件中,一般是.cpp文件,这样就可以在.cpp文件的顶端写代码,使头文件.h与.cpp互联,代码如下:
#include "***.h"
中间的*号是给该文件取的名字。该行语句的意思是将*.h文件读入cpp文件中,就如同将*.h文件的所有内容输入到cpp文件的开头一样。
.h文件加到.cpp文件中才能执行,它们之所以被分为两个文件,这是因为大多数情况下,类的使用者并不关心类在程序中的实现细节,他们只要阅读头文件就可知道所有关于类的信息,因此,他们可以忽略实现文件。另外,将类的定义和实现部分分开后,一个.h文件可以同时被多个.cpp文件调用。
下面我用上节的程序来演示.h和.cpp的使用方法。
在human.h中声明和定义类Human
#include <iostream>
using namespace std;
class A
{
public:
void func(int x,int y){i=x;j=y;}
void print(){cout<<"两数相乘为:"<<i*j<<endl;}
private:
int i,j;
};
在human.cpp中实现类Human
#include "Human.h"
void main()
{
A a;
a.func(5,2);
a.print();
system("pause");
}