#include头文件的顺序问题

daphant 2003-06-10 01:47:16
以前一直没有注意到这一点,比如一个程序要包括很多头文件,但是今天一编译,一下出来好几百个莫名其妙的错误,搞了半天,我把一个头文件换到了靠前一点的位置,竟然好了,谁能介绍一下,头文件的顺序有什么奥秘?
...全文
399 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
daphant 2003-06-10
  • 打赏
  • 举报
回复
啊!现在清楚多了
nullname 2003-06-10
  • 打赏
  • 举报
回复
nabie() 说的对
strongerman 2003-06-10
  • 打赏
  • 举报
回复
头文件的顺序是有讲究的,不能随意调换。除了stdafx.h ,还有一些头文件是这样
nabie 2003-06-10
  • 打赏
  • 举报
回复
某些头文件有相互依赖关系,比如 a.h 中用到的标识符或数据类型在 b.h 中定义,那么 b.h 就必须出现在 a.h 的前面,这个顺序不一定是你看到的顺序,而是当编译器把所有 #include 指令展开后把所有头文件放到 .c 或 .cpp 里的顺序。

另外 stdafx.h 必须放在第一位,主要原因是这个头文件与 stdafx.cpp 配合生成一个预编译的头文件供其他文件使用以提高编译的速度,因此编译器也会先编译这个 stdafx.cpp 文件。把 stdafx.h 放在第一位告诉编译器这个头文件前的所有代码都已经预编译了。SDK 和 MFC 的头文件被放在 stdafx.h 里,因为这些头文件一般不会改动且编译时需要耗费预处理器太多的时间。
wanghongit 2003-06-10
  • 打赏
  • 举报
回复
偶也遇见过,象StdAfx.h前面一般不能加别的头文件,你要用的添加的头文件声明一般在系统自动生成的头文件声明后加,只有这点感悟
至尊宝2021 2003-06-10
  • 打赏
  • 举报
回复
搂主的问题俺以前也遇到过.

原因有在相应的INCLUDE有类的实例生成,后有实例的调用,如果顺序反了,
当然就有很多莫名其妙的问题产生,或指针异常!!!

自己再去看看代码,会理解你的INCLUDE文件的先后问题的. -(:
pengweicn 2003-06-10
  • 打赏
  • 举报
回复
头文件有位置关系的问题吗?没有碰到过
只是尖括号和双引号的问题吧?
mlin2000 2003-06-10
  • 打赏
  • 举报
回复
头文件中使用条件编译,一般的有
#if !defined(AFX_DEVICEKEYBOARD_H__8B975467_4CB8_4D09_850D_5B95C047C21F__INCLUDED_)
#define AFX_DEVICEKEYBOARD_H__8B975467_4CB8_4D09_850D_5B95C047C21F__INCLUDED_

.........

#endif // !defined(AFX_DEVICEKEYBOARD_H__8B975467_4CB8_4D09_850D_5B95C047C21F__INCLUDED_)
zhucde 2003-06-10
  • 打赏
  • 举报
回复
我也没考虑过这个问题,也从来没遇到这个问题,

期待答案!
tpmao 2003-06-10
  • 打赏
  • 举报
回复
关注!!!!!关注!!!!!关注!!!!!关注!!!!!关注!!!!!关注!!!!!

16,471

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

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