大一学C++的时候,死板的记着“头文件声明函数,源文件实现函数,其余文件如果要用这个函数的话,包含头文件即可”。
虽然不知道为什么,但也没仔细想。后来仔细想想,略有所悟。
大一时间就这样写程序:
fun.h
int myAdd(int,int);
fun.cpp
#include "fun.h"
int myAdd(int a,int b)
{
return a+b;
}
main.cpp
#include <iostream>
using namespace std;
#include "fun.h"
int main()
{
cout<<myAdd(1,2);
return 0;
}
但是一直想不通的是,为什么我包含了fun.h后,编译器就知道我写的函数实体在fun.cpp里面呢?曾经我一度认为是函数声明和实现的文件同名就行了,也就是fun.h和fun.cpp的文件名都是fun。
直到有一天,我的膝盖中了一箭,我知道了#include在预处理过程中已经被展开了。所以上面的程序中编译器应该不直接接触fun.h,主程序中展开后变为
#include <iostream>
using namespace std;
//由#include展开
int myAdd(int,int);
int main()
{
cout<<myAdd(1,2);
return 0;
}
但是似乎还是解释不了,于是网上一查,原来函数声明默认为extern。所以
int myAdd(int,int);==extern int myAdd(int,int);
所以编译过程中,编译器也不知道int myAdd(int,int);的实现在哪个文件,因为是外部声明,所以编译器会在本文件和别的文件查找。