结论:static和inline作用的变量,其链接都会变为内部链接,也就是说变量只会再当前文件编译单元下生效。(编译单元:当一个c或cpp文件在编译时,预处理器首先递归包含头文件,形成一个含有所有 必要信息的单个源文件,这个源文件就是一个编译单元。也可以理解为一个cpp文件,就是一个编译单元)
实验:
同一个文件夹下有三个文件:ceshi.cpp / ceshi2.cpp 以及xjm2.h
ceshi2.cpp中定义了一个函数relu,xjm2.h中声明了这个函数relu,而ceshi.cpp中include了xjm2.h
一:正常运行如下:
1:ceshi.cpp:
2:ceshi2.cpp
3:xjm2.h
通过g++ ceshi.cpp ceshi2.cpp -o test
此时是可以正常编译运行的,说明ceshi.cpp文件中是可以访问到ceshi2.cpp文件中的函数的;
二:带上static以后
只修改ceshi2.cpp中的函数,再函数定义前加上static:
此时再编译,则报错:
原因是:
#include其实和extern比较类似,只不过#include复制整个文件,而extern则只是声明某一个函数不在本编译文本中,需要在其他文件中去找这个变量。
在xjm2.h中由于声明了这个函数,相当于就用了extern,而static作用范围是本文件,所以出现了上诉错误。
三:带上inline
此时在编译,则报错如下:
带上inline以后,报错是未定义函数
个人理解:内联函数,则会把本文件中所用用到这个函数别名的地方用函数中的具体实现代码替换,也就是说相当于没有这个函数了,此时我们在xjm2.h中声明的函数也就没有得到定义!!!