1.c++/c单独文件编译成.o文件后,最终通过链接生成最终可执行文件,
各个文件之间的访问的链接,是通过其方法名生成的。
2.c c++在生成方法名的时候是不相同的,因此单纯只是使用c,和单纯只使用c++直接生成.o文件,再链接的时候是找不到对应的方法的。
3.标准c库已经是.o文件了,因此不能对c函数名做更改
4.c++提供extern "C",表明该block内的函数均以c语言的方法进行方法名声明。
5.因此c++要调用标准c库,是通过extenr "C"来完成的。
下面操作说明:
1.main.cpp
#include <stdio.h>
int main(int argc, char** argv) {
printf("Hello world!\n");
return 0;
}
2.可能你会奇怪上面的代码并没有加extern "C",其实这是通过预处理的时候,自动添加上去的,另外还有一点,头文件其实只作用于预处理,预处理后,头文件的信息都会被包含到.e文件中,g++ -E main.cpp -o main.e
# 1 "main.cpp"
# 1 "<built-in>"
# 1 "<command-line>"
# 1 "/usr/include/stdc-predef.h" 1 3 4
# 1 "<command-line>" 2
# 1 "main.cpp"
# 1 "/usr/include/stdio.h" 1 3 4
# 27 "/usr/include/stdio.h" 3 4
# 1 "/usr/include/features.h" 1 3 4
# 374 "/usr/include/features.h" 3 4
# 1 "/usr/include/x86_64-linux-gnu/sys/cdefs.h" 1 3 4
# 385 "/usr/include/x86_64-linux-gnu/sys/cdefs.h" 3 4
# 1 "/usr/include/x86_64-linux-gnu/bits/wordsize.h" 1 3 4
# 386 "/usr/include/x86_64-linux-gnu/sys/cdefs.h" 2 3 4
# 375 "/usr/include/features.h" 2 3 4
# 398 "/usr/include/features.h" 3 4
# 1 "/usr/include/x86_64-linux-gnu/gnu/stubs.h" 1 3 4
# 10 "/usr/include/x86_64-linux-gnu/gnu/stubs.h" 3 4
# 1 "/usr/include/x86_64-linux-gnu/gnu/stubs-64.h" 1 3 4
# 11 "/usr/include/x86_64-linux-gnu/gnu/stubs.h" 2 3 4
# 399 "/usr/include/features.h" 2 3 4
# 28 "/usr/include/stdio.h" 2 3 4
extern "C" {
...
extern int printf (const char *__restrict __format, ...);
...
}
int main(int argc, char** argv) {
printf("Hello world!\n");
return 0;
}
因此,extern "C"的使用是预处理的时候,编译器帮我们做了,到这里相信也知道为何c++能像c代码一样直接使用标准c函数了