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