当一个文件(aa.c文件)依赖于头文件(bb.h)时,如果bb.c编译之后形成的bb.o文件重新编译后,aa.o的文件不需要重新编译
aa.c文件:
bb.h文件:对bb.c文件进行声明
bb.c文件:
有朋友就好奇了,明明bb.h里没有任何实现,为什么aa.c只导入bb.h就可以使用sum方法求和?
原因是:编译程序编译aa.c(其中含有main方法)时,发现它include了bb.h(其中声明了函数int sum(int,int)),那么此时编译器将按照事先设定的路径(include路径列表及代码文件所在的路径)查找与之同名的实现文件(拓展名为.cpp或.c,此案例是bb.c),如果找到该文件,并在其中找到该函数(int sum(int a,int b))的实现代码,则继续编译;如果在指定目录找不到实现文件,或者在该文件及后续的各include文件中未找到实现代码,则返回一个编译错误。学过设计模式3-依赖倒置的都知道,其实可以用一句话来解释这一现象:
高层主键(调用方)不依赖底层主键(被调用方),两者依赖于抽象。