define的用法
#define w Man
定义以后怎么输出q和w代表的字符串
求各位大神解答 展开
有三种用法,例如替代多行的代码、条件编译,还有典型的宏定义,具体如下:
1、define最重要的用法是条件编译
#ifdef WINDOWS
......
......
#endif
#ifdef LINUX
......
......
#endif
可以在编译的时候通过#define设置编译环境
2、典型的使用方法
使用宏定义我们可以自己根据自己的习惯来定义甚至改变C语言的语法习惯,例如:
#define BEGIN {
#define END }
int main()BEGIN
printf ("DEFINE----\n");
END
定义一个循环
#define LOOP for(;;)
重新定义数据类型
#define IT int
3、define可以替代多行的代码,在每一个换行的时候加上一个"\"
#define MAX(X,Y) do { \
语句1; \
语句2; \
/* 注释的写法 */ \
} while(0) /* (no trailing ; ) */ \
扩展资料:
参数
#define GPEBLT_FUNCNAME(basename) (SCODE (GPE::*)(struct GPEBltParms *))&GPE::##basename
在#define中,标准只定义了#和##两种操作。#用来把参数转换成字符串,##则用来连接前后两个参数,把它们变成一个字符串。
#include<stdio.h>
#define paster(n) printf("token"#n"=%d\n",token##n)
int main(void)
{
int token9=10;
paster(9);
return 0;
}
输出为:token 9 = 10
参考资料来源:百度百科-define (计算机专业用语)
#include<stdio.h>
int main(void)
{
#define q "Dead"
#define w "Man"
char * a = q,*b = w;
printf("%s\n%s\n",a,b);
return 0;
}
因为想要输出字符串类型,Dead和Man必须是字符串必须加 “ ”而" "必须加载Dead和Man上
而不能加载q和w上,虽然这俩个是等价的,不然后果为:
#include<stdio.h>
int main(void)
{
#define q Dead
#define w Man
char * a = "q",*b = "w";
printf("%s\n%s\n",a,b);
return 0;
}
#define的意思是宏定义, 格式:#define A B (注意这里没有分号“;”) 意思为用A表示B,但不对它进行正确性的检查,也就是无论你所代表的是否正确,编译器都会默认的不检查,在使用中宏定义可以用于定义一个常量如:#define pi 3.1415 这样,在程序中pi就是3.1415 你所写的q 就表示Dead ,w表示Man
但是因为它不检查它的正确性,所以,运用时,不可定义参数类型:
例:
#define pint int * //用pint代表int *类型(指针)
此时
pint a,b;就代表 int * a,b,此时a为int*类型,而b为整型的类型
与#define相对应的是typedef,编译器会对它进行正确性检查
typedef int* pint;(有分号,将pint 表示int *)
此时pint a,b;就代表 int * a和int * b,此时a和b均为int*的类型
在C或C++语言源程序中允许用一个标识符来表示一个字符串,称为“宏”。
被定义为“宏”的标识符称为“宏名”。
在编译预处理时,对程序中所有出现的“宏名”,都用宏定义中的字符串去代换,这称为“宏代换”或“宏展开”。
宏定义是由源程序中的宏定义命令完成的。
宏代换是由预处理程序自动完成的。
在C或C++语言中,“宏”分为有参数和无参数两种。
2. 无参宏定义
无参宏的宏名后不带参数。
其定义的一般形式为:
#define 标识符 字符串
其中的“#”表示这是一条预处理命令。凡是以“#”开头的均为预处理命令。“define”为宏定义命令。“标识符”为所定义的宏名。“字符串”可以是常数、表达式、格式串等。
例如:
#define M (a+b)
它的作用是指定标识符M来代替表达式(a+b)。在编写源程序时,所有的(a+b)都可由M代替,而对源程序作编译时,将先由预处理程序进行宏代换,即用(a+b)表达式去置换所有的宏名M,然后再进行编译。
程序1:
#define M (a+b)
main(){
int s,y;
printf("input a number: ");
scanf("%d",&y);
s=M*M;
printf("s=%d\n",s);
}
上例程序中首先进行宏定义,定义M来替代表达式(a+b),在 s= M * M 中作了宏调用。在预处理时经宏展开后该语句变为: S=(a+b)*(a+b)
但要注意的是,在宏定义中表达式(a+b)两边的括号不能少。否则会发生错误。
如当作以下定义后:#difine M (a)+(b)
在宏展开时将得到下述语句:S= (a)+(b)*(a)+(b) 对于宏定义还要说明以下几点:
1. 宏定义是用宏名来表示一个字符串,在宏展开时又以该字符串取代宏名,这只是一种简单的代换,字符串中可以含任何字符,可以是常数,也可以是表达式,预处理程序对它不作任何检查。如有错误,只能在编译已被宏展开后的源程序时发现。
2. 宏定义不是说明或语句,在行末不必加分号,如加上分号则连分号也一起置换。
3. 宏定义必须写在函数之外,其作用域为宏定义命令起到源程序结束。如要终止其作用域可使用#undef命令
3. 带参宏定义
c语言允许宏带有参数。在宏定义中的参数称为形式参数,在宏调用中的参数称为实际参数。对带参数的宏,在调用中,不仅要宏展开,而且要用实参去代换形参。
带参宏定义的一般形式为:
#define 宏名(形参表) 字符串
在字符串中含有各个形参。
带参宏调用的一般形式为:
宏名(形参表)
例如:
#define M(y) ((y)*(y)+3*(y)) /*宏定义*/
....
k=M(5); /*宏调用*/
....
在宏调用时,用实参5去代替形参y,经预处理宏展开后的语句为:
k=5*5+3*5
程序2:
#define MAX(a,b) (a>b)?a:b
main(){
int x,y,max;
printf("input two numbers: ");
scanf("%d%d",&x,&y);
max=MAX(x,y);
printf("max=%d\n",max);
}
上例程序的第一行进行带参宏定义,用宏名MAX表示条件表达式(a>b)?a:b,形参a,b均出现在条件表达式中。程序第七行max=MAX(x,y)为宏调用,实参x,y,将代换形参a,b。宏展开后该语句为:
max=(x>y)?x:y;
用于计算x,y中的大数。 4.防止重复定义
#define 条件编译
头文件(.h)可以被头文件或C文件包含;
重复包含(重复定义)
由于头文件包含可以嵌套,那么C文件就有可能包含多次同一个头文件,就可能出现重复定义的问题的。
通过条件编译开关来避免重复包含(重复定义)
例如
#ifndef __headerfileXXX__
#define __headerfileXXX__
„
文件内容
„
#endif
#define OS_EXT........................................2
#else..................................................3
#define OS_EXT extern................................4
#endif.................................................5
意思就是说,如果 OS_GLOBALS被定义,则本文件中的 OS_EXT被
替换为空(被忽略), 如果 OS_GLOBALS未被定义,则本文件中的
OS_EXT 被替换为 extern关键字. 意义比较明确, 就是给出了
本文件中哪些变量和函数,在何时需要使用 extern引用 (取决
于其他文件中有无定义 OS_GLOBALS.
为方便你理解, 举个例子.
现在有两文件 AAA.c和 BBB.c
AAA.c内容是
#define OS_GLOBALS
BBB.c内容是
#ifdef OS_GLOBALS
#define OS_EXT
#else
#define OS_EXT extern
#endif
OS_EXT void function1(void);
如果AAA.c先于BBB.c编译时,OS_GLOBALS被定义,在BBB.c里,实际上是
void function1(void); // 声明了自己的函数
如果BBB.c先于AAA.c编译,则OS_GLOBALS被定义,在BBB.c里,实际上是
extern void function1(void); // 声明了外部的一个函数.
另外,你想了解的比较重要的是,为什么define后面可以只有一个名字,这个语句的意思就是,将XXXX替换为空(从文本上忽略).比如
#define OS_EXT
意思就是说,在本文件中,凡OS_EXT文本串,在编译时都被替换成空白,被忽略,或者说删除.然而,这不影响它作为#ifdef判断的有效性,OS_EXT仍然是一个被define过的东西.就这个意思,应该理解了吧.
#ifdef OS_GLOBALS....................................1
#define OS_EXT........................................2
如果在#ifdef OS_GLOBALS前有过一句#define OS_GLOBALS,那么就会执行#define OS_EXT。否则不执行。