大家好,真的知道作用我是语言里小麦,今天是真的知道作用周末,但是语言里也不能停下学习的脚步。
我经常在C语言的真的知道作用头文件中看到下面的代码:
#ifdef __cplusplus extern "C" { #endif // all of your legacy C code here #ifdef __cplusplus } #endif这通常用于C++和C混合编程的时候,为了防止C++的语言里编译器在编译C文件的时候出现错误;
众所周知,云南idc服务商C++可以进行函数名重载,真的知道作用但是语言里C则没有这种功能,那这和extern "C"又有什么关系呢?真的知道作用
先看下面这个表格,如下所示;
语言 描述 C 函数名可以作为唯一ID和代码段的语言里程序建立联系 C++ 因为重载的关系,函数名符号会被破坏,真的知道作用从而会根据函数的语言里参数不同而重新生成函数符号test.h
#ifndef TEST_H #define TEST_H void foo1(void); void foo2(void); void foo3(int i); #endiftest.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可以看到函数符号已经被编译器修改了;
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 #endiftest.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函数的主意。
好了,这次分享的比较简单,也挺实用,我们下期再见。
本文转载自微信公众号「小麦大叔」,可以通过以下二维码关注。转载本文请联系小麦大叔公众号。