C和C++的相互调用.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
C和C的相互调用

C C++相互调用 在项目中融合C和C++有时是不可避免的,在调用对方的功能函数的时候,或许会出现这样那样的问题,但只要我的C代码和我的C++代码分别都能成功编译,那其他就不是问题。近来在主程序是C语言,而调用C++功能函数的时候,C++的*.h头文件都能找到,功能函数也都定义了,最重要的是,单独编译C++的时候,完全没有问题,但当用主程序的C调用C++的功能函数时,总是提示该函数未定义(undefined),这里分析问题的出处便是混合调用出现的问题了。 C++的*.h和*.cpp的 #ifdef __cplusplus extern C { #endif //一段代 #ifdef __cplusplus } #endif ??? 这样的代码到底是什么意思呢?首先,__cplusplus是cpp中的自定cpp的代:如果cpp的代extern C{和}   要明白extern C,cpp中c++中,.而在C中,只是.也就是:C++和C. 目的就是主要C与C++的相互 ? c.h的现 #ifndef _c_h_ #define _c_h_ #ifdef __cplusplus extern C { #endif void C_fun(); #ifdef __cplusplus } #endif #endif ----------------------------------- c.c的现 #include c.h void C_fun() { } ------------------------------------ 在cpp.cpp中c.c中的C_fun() cpp.cpp的现 #include c.h int main() { ???? C_fun() } 其中__cplusplus是C++C++编译器认为这个宏已经定义了. 所以extern C {}???? //这里告诉你的是__cplusplus不是最重要的,重要的是extern C {} extern C是告C++C的obj文件格式C的命名去找. ========================== 那C中是如何C++中的函数cpp_fun()呢?C写主程序,然后C++功能函数。 因C后有C++, 所以只能从C++的代 加入C++中的函数或C中的文件extern C{} 不C++中也 -------------------------------------- cpp.h的现 #ifndef _c_h_ #define _c_h_ #ifdef __cplusplus extern C { #endif void CPP_fun(); #ifdef __cplusplus } #endif #endif .------------------------------------------- Cpp.cpp的现 extern C {??? //告C+++编译器,扩号里按照C的命名译 void CPP_fun() { ???? ..... } } ?  C和C++.extern C是使C++能C写作的C的方式来extern C来 ? ??????? 下面摘extern? C的 ? 在C++ 程序中C 编译器编译后的函数,为什么要加extern “C”? ? 首先,作extern是C/C++ 通常,在模extern声明。例如,如果模B欲引用A中定A的B中A中的函数B虽然找不到该函数,但是并不会报错;它会在连接阶段中从模块A编译生成的目标代码中找到此函数 extern C是(linkage declaration),被extern C修C语言方式编译和连接的,来看看C++中C的函数是怎 作C++支持函数重C则不支持。函数被C++编译后在符号库中的名字与C语言的不同。例如,假设某个函数的原型为: void foo( int x, int y ); 该函数被C编译器编译后在符号库中的名字为_foo,而C++_foo_int_int之“mangled name”)。 _foo_int_int C++就是靠C++中,函数void foo( int x, int y )与void foo( int x, float y )_foo_int_float。 同C++中的.来区分。而本 未加extern C声明 假C++中,模A的件如下: // 模A头文件? moduleA.h #ifndef MODULE_A_H #define MODULE_A_H int foo( int x, int y ); #endif? ? 在模B中引用 // 模B实现文件? moduleB.cpp #i nclude moduleA.h foo(2,

文档评论(0)

kaiss + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档