C++調用C代碼
一個C語言文件p.c
#include <stdio.h>
void print(int a,int b)
{
printf("這里調用的是C語言的函數:%d,%d\n",a,b);
}
一個頭文件p.h
#ifndef _P_H
#define _P_H
void print(int a,int b);
#endif
C++文件調用C函數
#include <iostream>
using namespace std;
#include "p.h"
int main()
{
cout<<"現在調用C語言函數\n";
print(3,4);
return 0;
}
執行命令
gcc -c p.c
g++ -o main main.cpp p.o
編譯后鏈接出錯:main.cpp對print(int, int)未定義的引用。
-
編譯后鏈接出錯:main.cpp對print(int, int)未定義的引用。
-
原因分析
- p.c我們使用的是C語言的編譯器gcc進行編譯的,其中的函數print
編譯之后,在符號表中的名字為 _print - 我們鏈接的時候采用的是g++進行鏈接,也就是C++鏈接方式,程序在運行到調用
print函數的代碼時,會在符號表中尋找_print_int_int(是按照C
++的鏈接方法來尋找的,所以是找_print_int_int而不是找_print
)的名字,發現找不到,所以會t提示“未定義的引用” - 此時如果我們在對print的聲明中加入 extern “C” ,這個時候,g
++編譯器就會按照C語言的鏈接方式進行尋找,也就是在符號表中尋找_print
,這個時候是可以找到的,是不會報錯的。
- p.c我們使用的是C語言的編譯器gcc進行編譯的,其中的函數print
-
總結
- 編譯后底層解析的符號不同,C語言是_print,C++是_print_int_int
解決調用失敗問題
修改p.h文件
#ifndef _P_H
#define _P_H
extern "C"{
void print(int a,int b);
}
#endif
修改后再次執行命令
gcc -c p.c
g++ -o main main.cpp p.o
./main
運行無報錯
思考:那C代碼能夠被C程序調用嗎
實驗:定義main,c函數如下
#include <stdio.h>
#include "p.h"
int main()
{
printf("現在調用C語言函數\n");
print(3,4);
return 0;
}
重新執行命令如下
gcc -c p.c
gcc -o mian main.c p.o
報錯:C語言里面沒有extern “C“這種寫法
C代碼既能被C++調用又能被C調用
為了使得p.c代碼既能被C++調用又能被C調用
將p.h修改如下
#ifndef _P_H
#define _P_H
#ifdef __cplusplus
#if __cplusplus
extern "C"{
#endif
#endif /* __cplusplus */
void print(int a,int b);
#ifdef __cplusplus
#if __cplusplus
}
#endif
#endif /* __cplusplus */
#endif /* __P_H */
再次執行命令
gcc -c p.c
gcc -o mian main.c p.o
./mian
結果示意: