C++中宏的定义与用法(现已被内联函数所代替)

在noip中,宏还是被经常采用,所以这里讲一下,C++中宏的定义与用法

  1. 第一种用法——配合条件编译:#define DEBUG

定义一个叫DEBUG的标识符。它应该与#ifdef或#ifndef配合使用。举例如下:

#define DEBUG
#ifdef DEBUG
	void print(int v) { cout << v << endl;}
#else
	void print(int) {}
#endif

  

如果符号DEBUG存在,那么编译器会编译上面的、能输出数值的print,否则编译器编译下面的、什么事情都不做的print。

把上面的#ifdef换成#ifndef,那么编译的代码正好上面所说的相反。

    2.第二种用法——表达式

#define N  5000

  编译时,编译器会用类似于“查找和替换”的方法,把代码中的N换成5000。如果需要换成表达式,应该用括号把它们包围。例如:

#define a   1+2
#define b   (1+2)
c=a*2; d=b*2;

  

编译时上面一行会变成“c=1+2*2; d=(1+2)*1;”,显然它们的值是不同的。

此外,要注意表达式末尾不能有分号(除非你需要)。

3.第三种用法——简易“函数”

#define FtoC(a) (((a)-32)/9*5)

这类似于一个函数。不过,由于编译器只是进行简单替换,所以为了安全,a、b应该用括号包围,整个表达式也应该用括号包围。

这种“函数”用法和普通函数一样,且速度更快。然而,它很容易出现难以查出的错误。所以,请用内联函数(inline)代替宏定义。

注意,不要在“参数”中改变变量的值

  4.第四种用法——简化一段代码

#define move(dx, dy)	if (isfull(dir)) return; 				if (map(x+dx, y+dy)==‘0‘)				{										push(dir,x+dx,y+dy,head[dir], dep);					check(dir);							}

  

不要忘记每行后面的“\”,它相当于换行符。这次move简化了一大段代码。当然,在c++中内联函数也可以实现这种功能的。

时间: 2024-12-22 18:59:33

C++中宏的定义与用法(现已被内联函数所代替)的相关文章

带参宏定义和inline修饰的内联函数

带参宏定义和inline修饰的内联函数都是在编译时,用函数体替换掉宏调用或函数调用.这样用的好处是减少调用函数所花费的时间. 例如: 算法导论在讲到堆排序时说的,好的堆排序实现一般是把Left(i),Right(i),Parent(i)的实现通过宏定义或内联函数来实现,这就是因为当我们对一组数据使用堆排序时,会大量的调用left,right,parent函数定义成宏或内敛函数之后既不影响我们的代码阅读性又能是代码运行速度更快!

C++中对C的扩展学习新增语法——内联函数以及函数参数

内联函数以及函数参数 内联函数 使用 inline 关键字必须和函数体放在一起. 内联函数具有内部链接属性. 内联函数会被编译器在编译阶段替换到函数调用的地方. 可以把内联函数定义写到头文件中,多个cpp包含时不会引起重定义. 如果出现连接错误: 使用第三方库,没有将其库代码配置到项目,所以导致编译器找不到实现(变量定义,函数定义) 本身自己只写了声明,根本没有定义实现. 变量本身.函数本身具有内部链接属性,此函数或者变量只能在当前文件访问. 函数参数 函数参数的作用 兼容C语言中不规范的语法

内联函数和宏定义的区别和联系

深入到计算机的本质,其实,很多东西还是细节需要深入分析的,比如我最近的一份工作 内联函数和宏很类似,都是以空间换时间,都能一定程度上加快程序的执行.而区别在于,宏是由预处理器对宏进行替代,而内联函数是通过编译器控制来实现的.而且内联函数是真正的函数,只是在需要用到的时候,内联函数像宏一样的展开,所以取消了函数的参数压栈,减少了调用的开销.你可以象调用函数一样来调用内联函数,而不必担心会产生于处理宏的一些问题.当然,内联函数也有一定的局限性.就是函数中的执行代码不能太多了,如果,内联函数的函数体过

内联函数与宏定义的区别

内联函数与宏的区别: 内联函数与普通函数相比,可以加快程序的运行速度,因为不需要中断调用,在编译的时候内联函数可以直接镶嵌到目标代码中.而宏只是简单的字符替换. 内联函数要做参数类型检查,这是内联函数跟宏相比的优势. inline一般只用于如下情况: (1)一个函数不断被重复调用 (2)函数只有简单的几行,且不包含for.while.switch等语句. 一般而言,写小程序没有必要使用inline,但是如果要完成一个工程项目,当一个简单函数被调用多次时,应考虑使用inline

内联函数与宏

宏,我们有时会定义一些预处理宏,如 #define COMP(x) ((x)>0?(x):0) 就定义了一个宏. 使用宏的原因是——函数调用有一定的时间和空间开销(在函数调用的使用程序跳到函数所在内存中的地址,执行完之后再跳回原来的位置继续执行.这种转移需要保存现场并记忆当前内存位置,执行完函数之后再恢复现场),而宏只是在预处理的地方把代码展开,不需要额外的时间空间开销,因而提高了效率. 内联函数,使用Inline来定义,在类的内部定义了函数体的函数被默认为内联函数. 内联函数在C++类中,应用

C++中的内联函数和C中的宏定义的区别

在C++中内联函数: 内联函数即是在函数的声明和和定义前面加上“inline”关键字,内联函数和常规函数一样,都是按照值来传递参数的,如果参数为表达式,如4.5+7.5,则函数将传递表达式的值(这里为12),而宏定义则不同. 在C中的宏定义: C语言使用的预处理器语句#define来提供宏,例如:#define SQUARE(X)  X*X,这里宏并不是通过值传递来实现的,而是通过文本替换来实现的. 内联函数和宏定义的区别用下面的代码来观察: //内联函数 inline double squar

深入探讨 内联函数和宏定义的区别

内联函数的执行过程与带参数宏定义很相似,但参数的处理不同.带参数的宏定义并不对参数进行运算,而是直接替换:内联函数首先是函数,这就意味着函数的很多性质都适用于内联函数,即内联函数先把参数表达式进行运算求值,然后把表达式的值传递给形式参数. 内联函数与带参数宏定义的另一个区别是,内联函数的参数类型和返回值类型在声明中都有明确的指定:而带参数宏定义的参数没有类型的概念,只有在宏展开以后,才由编译器检查语法,这就存在很多的安全隐患. 使用内联函数时,应注意以下问题: 1)内联函数的定义性声明应该出现在

宏定义与内联函数

1.宏定义的规则和使用解析(1)宏定义的解析规则就是:在预处理阶段由预处理器进行替换,这个替换是原封不动的替换.(2)宏定义替换会递归进行,直到替换出来的值本身不再是一个宏为止.(3)一个正确的宏定义式子本身分为3部分:第一部分是#dedine ,第二部分是宏名 ,剩下的所有为第三部分.(4)宏可以带参数,称为带参宏.带参宏的使用和带参函数非常像,但是使用上有一些差异.在定义带参宏时,每一个参数在宏体中引用时都必须加括号,最后整体再加括号,括号缺一不可. 宏定义示例1:MAX宏,求2个数中较大的

内联函数和宏定义

内联函数的优点? 内联函数和普通函数相比可以加快程序运行的速度,因为不需要中断调用. inline是指嵌入代码,就是在调用函数的地方不是跳转,而是把代码直接写到那里去, 减少了普通函数调用时的消耗. 什么时候使用inline函数? 一个函数不断被重复调用. 函数只有简单的几行,且函数内不包含for.while.switch语句. 以下情况不宜使用内联: 函数体的代码比较长. 函数体内出现循环. 类的构造函数和析构函数. 内联函数和宏的共同点是什么? 空间换时间 内联函数和宏定义的差别是什么? 宏