c语言 变量不跨文件使用,C语言中跨文件的全局变量

本文探讨了C语言中全局变量的定义与连接过程,并通过实例解释了初始化与未初始化全局变量的区别及其对链接器行为的影响。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

声明:突然看到这篇文章,发现了c语言中使用全局变量的错误,特转之。

func.c

int

buf

=

0

; void

func

()

{ buf

=

2

; /* Do something else */ }

main.c

#include int

buf

; void

func

(); int

main

()

{ buf

=

1

; func

(); printf

(

"%d

\n

"

,

buf

); return

0

; }

编译两个文件,输出的结果是怎样的呢?一眼看上去,可能会输出1,因为两个全局变量buf在不同文件中,又没有extern声明,显然是两个嘛。然而实际上它的运行结果却是2,这说明了这两个文件中引用到的其实是一个变量!

这是为什么呢?原因是在编译时,C语言编译器将全局符号标记为strong和weak两类:

函数和初始化的全局符号被标记为strong

未初始化的全局符号被标记为weak

连接时,连接器对多重定义的全局符号的解析原则如下:

同一个符号不允许有多个strong定义;

假如一个符号有一个strong定义和多个weak定义,那么采用该符号的strong定义;

假如一个符号有多个weak定义,那么选取任意一个weak定义

由于两个变量一个初始化了,一个没有初始化,所以一个是strong,一个是weak,所以连接器在符号解析时会把他们当成一个。

如果我们把main.c中的buf也初始化了:

#include int

buf

=

0

; void

func

(); int

main

()

{ buf

=

1

; func

(); printf

(

"%d

\n

"

,

buf

); return

0

; }

再次编译就会发现

duplicate symbol _buf in:

/var/folders/44/_cc501qx1jd1p5bfrjbk6b100000gn/T//ccZ87C6g.o

/var/folders/44/_cc501qx1jd1p5bfrjbk6b100000gn/T//ccZlES8n.o

ld: 1 duplicate symbol for architecture x86_64

collect2: ld returned 1 exit status

这是因为两个全局变量都是strong的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值