zoukankan      html  css  js  c++  java
  • C++调用C函数

    http://blog.csdn.net/imcainiao11/article/details/7369447

    前言:以前见到extern "C"这样的语句,只是简单地知道跟外部链接有关,但是没有深刻理解它的意思。

    首先,为什么要使用extern "C"修饰符?

    C++调用其它语言的函数,由于编译器生成函数的机制不一样,所以需要经过特殊处理,才可以调用。调用C语言的函数,需要在函数声明的地方语句extern "C"。如果不使用该语句,在链接的时候,编译器就会报以下这种错误。

    Test.obj : error LNK2019: 无法解析的外部符号 "void __cdecl DeleteStack(struct _Node *)" (?DeleteStack@@YAXPAU_Node@@@Z),该符号在函数 _main 中被引用。

    然后是如何使用?

    应该怎么使用该语句呢?

    刚开始,我简单地在C++源文件的前面使用该语句声明,但是还是出错,而且是在编译阶段就报错。

    [cpp] view plain copy
     
    1. error C2732: 链接规范与“DeleteStack”的早期规范冲突。  

    为什么会出现这个错误呢?因为C++源文件已经引入了C的头文件,在头文件里,声明该函数时没有extern修饰,而这里有extern修饰,所以冲突了。解决的办法有两个。

    一。在C头文件中加上extern修饰符。

    直接加,也不行。因为C源文件也包含了这个头文件,当编译C源文件时,就会出现错误。所以,需要一种机制来区分是编译C还是C++文件。方法如下:

    [cpp] view plain copy
     
    1. #ifdef __cplusplus  
    2. extern "C"  
    3. #endif  
    4.  void DeleteStack(Stack stack);  


    因为在编译C++文件时,自动定义预处理器名字__cplusplus,而编译C时,没有该处理器名字。所以只有编译C++时,才有符号extern “C”。

    此外,链接指示extern "C"有单个和复合两种形式。以上为单个形式,复合形式可以同时将几个函数声明为extern "C"

    [cpp] view plain copy
     
    1. extern "C" {  
    2. void DeleteStack(Stack stack);  
    3. void PrintStack(Stack stack);  
    4. void Pop(Stack stack);  
    5. }  


    加上预处理器名字如下:

    [cpp] view plain copy
     
    1. #ifdef __cplusplus  
    2. extern "C" {  
    3. #endif  
    4.   
    5. void DeleteStack(Stack stack);  
    6. void PrintStack(Stack stack);  
    7. void Pop(Stack stack);  
    8.   
    9. #ifdef __cplusplus  
    10. }  
    11. #endif  


    二。编写一个C++风格的头文件,在这里添加extern修饰符。

    使用方法一,很简单。但是如果该头文件是别人写好,你无法修改。这个时候就要使用其它方法了。方法是定义C++自己的头文件,文件名为"CStack.h"

    [cpp] view plain copy
     
      1. // CStack.h  
      2. extern "C" {  
      3. #include "Stack.h";  
      4. }  
  • 相关阅读:
    310. Minimum Height Trees
    279. Perfect Squares
    675. Cut Off Trees for Golf Event
    210. Course Schedule II
    407. Trapping Rain Water II
    vue-element-admin中如何vuex的使用
    webpack相关---vue-element-admin
    公共vendor是什么---vue-element-admin
    项目mock 模拟数据---vue-element-admin
    vue+ssr signalR---vue-element-admin
  • 原文地址:https://www.cnblogs.com/leaven/p/6247982.html
Copyright © 2011-2022 走看看