长见识:你真的知道C语言里extern "C" 的作用吗?

经常在C语言的头文件中看到下面的代码:

#ifdef __cplusplus
extern "C" {
#endif

// all of your legacy C code here

#ifdef __cplusplus
}
#endif

这通常用于C C混合编程的时候,为了防止C 的编译器在编译C文件的时候出现错误;
众所周知,C 可以进行函数名重载,但是C则没有这种功能,那这和extern "C"又有什么关系呢?
先看下面这个表格,如下所示;

语言描述
C函数名可以作为唯一ID代码段的程序建立联系
C 因为重载的关系,函数名符号会被破坏,从而会根据函数的参数不同而重新生成函数符号

未添加 extern "C"

test.h

#ifndef TEST_H
#define TEST_H

void foo1(void);
void foo2(void);
void foo3(int i);

#endif

test.c


void foo1(void){}
void foo2(void) {}
void foo3(int i){}

int main(int argc,char** argv){
 
 foo1();
 foo2();
 foo3(1); 
 return 0;
}

编译这两个文件,生成test.o文件,通过objdump查看函数符号;

g   -c test.c test.h
objdump -t test.o

可以看到函数符号已经被编译器修改了;

添加extern "C"

test.h

#ifndef TEST_H
#define TEST_H

#ifdef __cplusplus
extern "C" {
#endif
void foo1(void);
void foo2(void);
void foo3(int i);

#ifdef __cplusplus
}
#endif

#endif

test.c

#ifdef __cplusplus
extern "C" {
#endif
void foo1(void){}
void foo2(void) {}
void foo3(int i){}
#ifdef __cplusplus
}
#endif

int main(int argc,char** argv){
 
 foo1();
 foo2();
 foo3(1); 
 return 0;
}

编译这两个文件,生成test.o文件,通过objdump查看函数符号;

g   -c test.c test.h
objdump -t test.o

这时候函数符号是正确的;

extern "C" 是告诉C 的编译器不要打我这些C函数的主意。

声明:

本文于网络整理,版权归原作者所有,如来源信息有误或侵犯权益,请联系我们删除或授权事宜。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值