一个非常奇怪的问题(关于#include)

charles8513 2006-09-10 11:28:09
以下代码提示不认识的表示符sin和cos:
#include "math.h"
#include "stdafx.h"

#include "EX_Draw2_0201.h"

#include "EX_Draw2_0201Doc.h"
#include "EX_Draw2_0201View.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

......
void CEX_Draw2_0201View::OnDraw(CDC* pDC)
{
CEX_Draw2_0201Doc* pDoc = GetDocument();
ASSERT_VALID(pDoc);
const double PI=3.1415926,_2PI=PI+PI;
const int r=200,deg1=25,deg2=150;
const int x0=r+20,y0=r+20,x1=x0-r,y1=y0-r,x2=x0+r,y2=y0+r;

// TODO: add draw code for native data here
int x3,y3,x4,y4;
float rad1=deg1*PI/180,rad2=deg2*PI/180;
CBrush br,*p_br;
br.CreateSolidBrush(RGB(255,0,0));
p_br=pDC->SelectObject(&br);


x3=x0+r*cos(rad1);
y3=y0+r*sin(rad1);
x4=x0+r*cos(rad2);
y4=y0+r*sin(rad2);


pDC->Pie(x1,y1,x2,y2,x4,y4,x3,y3);
pDC->SelectObject(p_br);
br.DeleteObject();
}


但是如果将前面的#include语句换个顺序就好了,就是不要将#include "math.h"放到最前面就可以了,比如:

#include "stdafx.h"
#include "math.h"
#include "EX_Draw2_0201.h"

#include "EX_Draw2_0201Doc.h"
#include "EX_Draw2_0201View.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
...全文
90 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
truewill 2006-09-10
  • 打赏
  • 举报
回复
好似是因为stdafx.h是一个叫precompile header之类的,所以总是放在最顶的
呵呵,其实我什么也不知道 ^_^
jixingzhong 2006-09-10
  • 打赏
  • 举报
回复
stdafx.h 是VC 的特殊 预编译 单元,
它必须在最上面,
或者说,
一切从 stdafx.h 这里开始 ...

一般头文件的包含是不存在顺序问题的,
但是 VC 中偶尔有这个问题,
stdafx.h 是一个,另外还碰到过一个 ....
wqvbka123 2006-09-10
  • 打赏
  • 举报
回复
JF
菜牛 2006-09-10
  • 打赏
  • 举报
回复
stdafx.h需要放在最前面。

16,471

社区成员

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

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

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