一、用法不同
1、.h文件直接#include到需要的.cpp文件里,就相当于把.h文件的代码拷贝到.cpp文件
2、.cpp文件需要先自己生成.o文件,把不同.o文件连接生成可执行文件。
比如有3个cpp文件:a.cpp、b.cpp、c.cpp,其中一个包含main()函数,需要生成test程序,
步骤:
(1)生成3个.o文件:
cc -c a.cpp
cc -c b.cpp
cc -c c.cpp
这样就得到3个.o文件:a.o、b.o、c.o
(2)链接生成test程序:cc -o test a.o b.o c.o
就得到test可执行程序,输入./test就可执行程序了。
二、规范不同
1、h文件一般包含类声明;
2、cpp文件一般为同名h文件定义所声明的类函数。
说明:一般可在cpp文件直接添加main()就可以测试该模块功能。
扩展资料:
放在.h里的数学计算公式:
1、 三角函数
double sin(double);正弦
double cos(double);余弦
double tan(double);正切
2 、反三角函数
double asin (double); 结果介于[-PI/2,PI/2]
double acos (double); 结果介于[0,PI]
double atan (double); 反正切(主值),结果介于[-PI/2,PI/2]
double atan2 (double,double); 反正切(整圆值),结果介于[-PI,PI]
3 、双曲三角函数
double sinh (double);
double cosh (double);
double tanh (double);
4 、指数与对数
double frexp(double value,int *exp);这是一个将value值拆分成小数部分f和(以2为底的)指数部分exp,并返回小数部分f,即f*2^exp。其中f取值在0.5~1.0范围或者0。
double ldexp(double x,int exp);这个函数刚好跟上面那个frexp函数功能相反,它的返回值是x*2^exp
double modf(double value,double *iptr);拆分value值,返回它的小数部分,iptr指向整数部分。
double log (double); 以e为底的对数
double log10 (double);以10为底的对数
double pow(double x,double y);计算x的y次幂
float powf(float x,float y); 功能与pow一致,只是输入与输出皆为单精度浮点数
double exp (double);求取自然数e的幂
double sqrt (double);开平方根
5 、取整
double ceil (double); 取上整,返回不比x小的最小整数
double floor (double); 取下整,返回不比x大的最大整数,即高斯函数[x]
6 、绝对值
double fabs (double);求实型的绝对值
double cabs(struct complex znum);求复数的绝对值
一般的数据,数据结构,接口,还有类的定义放在.h文件中,可以叫他们头文件,可以#include 到别的文件中。功能实现一般都放在具体的.cpp文件中,这样方便文件管理,节约时间,提高效率。
你完全可以把功能实现一并放在.h文件中,也可以#include一个.cpp文件到另一个源文件中,这样编译可以通过,但不方便查看与管理,程序(或项目)稍微大点,容易造成混乱。
需要在.c或者.cpp中使用include<xxx.h>加载到代码文件中才会被执行.
你可以试着用文本模式打开.h文件,里面的代码跟.cpp或者.c是一样的,不过.h可能会没有main函数.
我举个栗子: .c或.cpp文件是枪,那么里面的代码就像弹夹或枪膛里的子弹属于正在使用的,而.h就像弹药库里的子弹,如果你要用.h 那么就要到弹药库里把你要的子弹拿出来,上到弹夹里面,也就是在.c或.cpp文件里面写入#include<xxx.h>
.dll跟.h起的作用是一样的,只不过实现方式不同,就不详细说了.