TRACE :
等同于 TRACE0,后面的 TRACE1、TRACE2、TRACE3,后面的数字表示需要的参数个数。
宏:只是一种定义,它定义了一个语句块,当程序编译时,编译器首先要执行一个“替换”源程序的动作,把宏引用的地方替换成宏定义的语句块,就像文本文件替换一样。称为:宏的展开。
#define N 3
#define Y(n) ((N+1)*n)
#define P(n) ((N+1)*(n))
void CTestDlg::OnOK()
{ //对宏的理解-例子
int z = 2*(N+Y(5+1));
TRACE("%s", "\n=================\r\n");
TRACE("z(Y) = { 2*(3 + 4* 5+1) } = %d", z);
z = 2*(N+P(5+1));
TRACE("%s", "\n---\r\n");
TRACE("z(P) = { 2*(3 + 4*(5+1) } = %d", z);
TRACE("%s", "\n=================\r\n");
CDialog::OnOK();
}
结果:
=================
z(Y) = { 2*(3 + 4* 5+1) } = 48
---
z(P) = { 2*(3 + 4*(5+1) } = 54
=================