解决 c++ 调用 c 函数报错: undefined reference to 'xxx' 的问题

发布时间:2024-04-17 18:30:33 作者:yexindonglai@163.com 阅读(61)

先上代码

main.cpp

  1. #include "func.h"
  2. int main() {
  3. return add(1,4);
  4. }

func.h

  1. #ifndef UNTITLED_FUNC_H
  2. #define UNTITLED_FUNC_H
  3. int add(int a,int b);
  4. #endif //UNTITLED_FUNC_H

func.c

  1. #include "func.h"
  2. int add(int a,int b){
  3. return a+ b;
  4. }

CMakeLists.txt

  1. cmake_minimum_required(VERSION 3.23)
  2. project(untitled)
  3. set(CMAKE_CXX_STANDARD 11)
  4. include_directories(./include)
  5. add_executable(untitled main.cpp src/func.c include/func.h)

代码结构如下图

编译

以上代码中只有main.cpp 是c++文件,其他文件都是c语言的;当进行编译后会提示以下错误:

  1. ====================[ Build | untitled | Debug ]================================
  2. /usr/local/cmake_3.23.0/cmake-3.23.0/bin/cmake --build /tmp/tmp.HB9zcw9fre/cmake-build-debug --target untitled -- -j 22
  3. Consolidate compiler generated dependencies of target untitled
  4. [ 33%] Building CXX object CMakeFiles/untitled.dir/main.cpp.o
  5. [ 66%] Building C object CMakeFiles/untitled.dir/src/func.c.o
  6. [100%] Linking CXX executable untitled
  7. /usr/bin/ld: CMakeFiles/untitled.dir/main.cpp.o: in function `main':
  8. /tmp/tmp.HB9zcw9fre/main.cpp:3: undefined reference to `add(int, int)'
  9. collect2: error: ld returned 1 exit status
  10. gmake[3]: *** [CMakeFiles/untitled.dir/build.make:113: untitled] Error 1
  11. gmake[2]: *** [CMakeFiles/Makefile2:83: CMakeFiles/untitled.dir/all] Error 2
  12. gmake[1]: *** [CMakeFiles/Makefile2:90: CMakeFiles/untitled.dir/rule] Error 2
  13. gmake: *** [Makefile:124: untitled] Error 2

东西太多,我们只需要关注这一行,意思是找不到 add(int, int) 函数

  1. /tmp/tmp.HB9zcw9fre/main.cpp:3: undefined reference to `add(int, int)'

这是因为.cpp 文件默认使用的是 c++编译器, 而 .c 文件默认使用的是 c 编译器,实际在编译的过程中,.cpp 文件调用 .c 文件中的函数就会出错.

至于为什么不能这么干,这篇文章说的很清楚, 有兴趣的请戳: https://blog.csdn.net/challenglistic/article/details/130223118

解决方案一

  • 将所有的 .c 文件后缀改为 .cpp;所有的 .h 改为 .hpp
  • 或者将所有的 .cpp 文件后缀改为 .c,所有的 .hpp 改为 .h(注意:代码中未用到 c++ 特性才能这么干)

解决方案二

在所有的.h文件头尾加上以下代码即可, 注意,只加头文件即可

  1. #ifdef __cplusplus
  2. extern "C" {
  3. #endif
  4. // 函数声明
  5. #ifdef __cplusplus
  6. }
  7. #endif

加完后运行如下图,可以正常运行了

关键字c++