大一学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);的实现在哪个文件,因为是外部声明,所以编译器会在本文件和别的文件查找。