先看一个例子:
输出:
当在main函数中引用p函数进行输出的时候为什么会出现这种输出结果呢?
原因如下:
1.先明白链接时符号的类型。
(1)模块内部定义的全局符号,可以被其他模块引用的符号
例如:不带static关键字的c函数和全局变量
(2)外部定义的全局符号,可以在本模块中使用的符号
例如:有extern引用的符号
(3)模块中的局部符号
例如:模块中带static的c函数和局部变量
2.其次明白什么是强符号什么是弱符号。
注:强弱只针对全局符号
- 强符号:函数名和已经初始化的全局变量名是强符号
- 弱符号:未初始化的全局变量名是弱符号
3.链接时对符号的解析规则。
(1)强符号只能定义一次
(2)当一个符号被定义为一次强符号和多次弱符号以强符号为准(即对弱符号的引用解析为强符号)
(3)若有多个弱符号则任选一个
回到这个问题:
两个模块中对p有了双重定义。int d 进行了初始化,double d 没有进行初始化。按照强弱符号之分int d 是强符号,double d 是弱符号。由于编译时,每个模块都是单独进行编译的,所以p会先赋予double d,底层用64位浮点数存储为:3FF0 0000 0000 0000H
当进行链接时,会以强符号 (int) d为主。
所以在执行到调用p()函数时,会将浮点数 3FF0 0000 0000 0000H 赋予int d所在的存储空间,由于int 只有4B 所以会连带覆盖之后声明的int x。
若以小端模式存储,会如此进行存储。
最后以10进制输出时,就会输出: