[c/c++互相包含困惑]c文件包含c++头文件

boborookie 2009-11-25 05:10:05
用.c文件去包含一个 cpp定义的头文件,结果报出类似以下的一大堆错误:
expected ';', ',' or ')' before '&' token
expected declaration specifiers or '...' before 'UsFileOpenMode'

情况是这样的:
有以下文件:
cfile.c
cppfile1.cpp
cppfile1.h
cppfile2.cpp

在cppfile2.cpp中 #include "cppfile1.h" 就完全正常,没有任何问题
但是如果在cfile.c中 #include "cppfile1.h" 就会报出以上那些错误

所以想请教:
是因为c++的头文件不能被 c文件包含么?
如果是这样,是因为 c编译器无法识别c++编译器标识的函数吗?

另外,引申出来的问题:
1. c++ 使用 c 的文件,需要在c的头文件里加 extern "C" {}
2. c 使用 c++的文件,是要在c++ 头文件和实现文件里 也加 extern "c" 吗?
这样,其它 c++文件在使用这个 c++头文件时,ok吗?
3. 还有其它什么注意事项,也请多多指点 多谢!

...全文
3780 11 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
毒行江湖 2010-12-21
  • 打赏
  • 举报
回复
好麻烦啊,都看不懂了我
荃子 2010-06-08
  • 打赏
  • 举报
回复
很详细,以后会受用,先收了。
boborookie 2009-11-28
  • 打赏
  • 举报
回复 1
再补充之前的做法:
将c文件需要的cpp函数单独提取出来,

cppfunc.cpp:
#include "cppfunc.h"
#ifdef __cplusplus
#if __cplusplus
extern "C" {
#endif
#endif

void func1()
{
...
}
#ifdef __cplusplus
#if __cplusplus
}
#endif
#endif

cppfunc.h:
#ifdef __cplusplus
#if __cplusplus
extern "C" {
#endif
#endif

extern void func1();

#ifdef __cplusplus
#if __cplusplus
}
#endif
#endif

//然后在c文件中直接include 该头文件
cfile.c
#include "cppfunc.h"
void main(argc, argv)
{
func1();//这里直接调用即可
}


以上方法验证是可行的,
之前看到:
"而在C语言的头文件中,对其外部函数只能指定为extern类型,C语言中不支持extern "C"声明,在.c文件中包含了extern "C"时会出现编译语法错误。
"
而c++头文件是支持extern "C"的,所以可以如上使用。

总结以上的方法:
1. 将c文件需要的c++函数提取出来
放到另一个单独的c++文件中,
2. 并在该文件及其头文件都加extern "C"
3. 然后在c文件中include 其头文件即可

不会太拗口吧 汗。。
boborookie 2009-11-28
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 boborookie 的回复:]
最终的解决方法:
.c文件需要的几个函数原本在.cpp文件中
将这些函数提取出来,放到另外一个.cpp和.h 中,并在这2个文件中添加 extern "C"

然后在.c文件中包含该.h即可。

这个隐约觉得不是最理想的方法

但是 __cplusplus 是哪里定义的?是 c++的compiler吗?

这个方法果然是有问题的,因为.cpp中也使用了
#ifdef __cplusplus
extern "C" {
#endif
这样,这个.cpp文件实际上就是.c文件了
它的编译和连接都是 c 规则
这样也不能算错,是把c文件需要的cpp函数完全移到了另一个c文件中
这种做法不赞成!

更好的做法是:
"在C中引用C++语言中的函数和变量时,C++的头文件需添加extern "C",但是在C语言中不能直接引用声明了extern "C"的该头文件,应该仅在C文件中将C++中定义的extern "C"函数声明为extern类型"
例如:
//C++头文件 cppExample.h
#ifndef CPP_EXAMPLE_H
#define CPP_EXAMPLE_H
extern "C" int add( int x, int y );
#endif
//C++实现文件 cppExample.cpp
#include "cppExample.h"
int add( int x, int y )
{
 return x + y;
}
/* C实现文件 cFile.c
/* 这样会编译出错:#include "cExample.h" */
extern int add( int x, int y );
int main( int argc, char* argv[] )
{
 add( 2, 3 );
 return 0;
}

本文来自CSDN博客:
http://blog.csdn.net/lbzhao_28/archive/2008/10/27/3159598.aspx


[/Quote]
brookmill 2009-11-27
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 boborookie 的回复:]
但是 __cplusplus 是哪里定义的?是 c++的compiler吗?
[/Quote]
对,是c++编译器预先定义的。
如果它被定义了,就说明现在正在使用的编译器是c++
http://blog.csdn.net/minyangchina/archive/2009/11/03/4760257.aspx
http://blog.csdn.net/lbzhao_28/archive/2008/10/27/3159598.aspx
brookmill 2009-11-26
  • 打赏
  • 举报
回复
c++头文件里难免有些类、引用等等c语言里面没有的东西,把他们包含到c文件里,gcc可处理不了。
比如楼主提到的 expected ';', ',' or ')' before '&' token
多半就是因为某个函数声明里有引用。

我觉得,c文件包含c++文件不太好,首先应该设法从设计上避免。
为什么要包含这个头文件?大概是为了宏定义、函数声明等等,既然这些东西要被c文件用到,那么就应该尽量把他们都单独拿出来作为一个c的头文件。

如果一定要让c文件包含c++文件,那就只能设法让c编译器看不到那些只有c++才能支持的东西。比如这样:
#ifdef __cplusplus
class { ... };
#endif
XyRbj 2009-11-26
  • 打赏
  • 举报
回复
都说得很详细了
hurongfz 2009-11-26
  • 打赏
  • 举报
回复
学习了
boborookie 2009-11-26
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 boborookie 的回复:]
最终的解决方法:
.c文件需要的几个函数原本在.cpp文件中
将这些函数提取出来,放到另外一个.cpp和.h 中,并在这2个文件中添加 extern "C"
格式如下:
#ifdef __cplusplus
#if __cplusplus
extern "C" {
#endif
#endif

然后在.c文件中包含该.h即可。

这个隐约觉得不是最理想的方法

这个方法值得学习
#ifdef __cplusplus
class { ... };
#endif

但是 __cplusplus 是哪里定义的?是 c++的compiler吗?

[/Quote]
boborookie 2009-11-26
  • 打赏
  • 举报
回复
最终的解决方法:
.c文件需要的几个函数原本在.cpp文件中
将这些函数提取出来,放到另外一个.cpp和.h 中,并在这2个文件中添加 extern "C"

然后在.c文件中包含该.h即可。

这个隐约觉得不是最理想的方法

这个方法值得学习
#ifdef __cplusplus
class { ... };
#endif

但是 __cplusplus 是哪里定义的?是 c++的compiler吗?
danny 2009-11-25
  • 打赏
  • 举报
回复
等别人回答我的问题,顺便把我知道的说下吧.

我所碰到的c\c++混编,C++头文件不能被C文件包含.

1.是.
2.简单的方法是,在cpp文件中,把#include 的C头文件用Extern "c" {}括起来就行了.或者在整个C头文件中.
不会受到影响.

3.其它的貌似没有了...碰到再问吧.

23,215

社区成员

发帖
与我相关
我的任务
社区描述
Linux/Unix社区 应用程序开发区
社区管理员
  • 应用程序开发区社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧