在C++中自定义宏的简单方法

 更新时间:2015年07月15日 09:18:11   投稿:goldensun  
这篇文章主要介绍了在C++中自定义宏的简单方法,作者建议使用类似定义函数一样的方法来定义宏,需要的朋友可以参考下

可以使用宏定义没有返回值的“函数”。例如:

 

复制代码 代码如下:
#define PrintMax(a, b) \   do \   { \     int x = a, y = b; \     printf("Max: %d\n", x > y ? x : y);\   } while (0) // ... PrintMax(3, 4);

    这样的“函数”与真正意义上的函数有本质的区别,因为宏是一个编译前行为,仅仅是编译前对文本进行替换。在Python源码中,经常可以看到下面类似的宏定义:

 #define foo(x) \ do { \  ... \ } while (0) 

    为什么要使用do { ... } while (0)这样的语法而不直接使用 { } 呢?定义了上面这个宏,我们就可以在代码中使用类似这样的代码:foo(3); 注意结尾的分号,它看起来很像一个函数,实现上它表示一条语句。如果使用 { } 来代替 do { ... }  while (0),那么使用分号显然是个语法错误。

    使用宏时,有几点要特别注意:

    要特别留心空格。下面的两个宏是一样的:

 #define foo(x) (x << 2) #define boo (x) (x << 2) //注意括号前面的空格 

    用宏给类型取别名与typedef有很大的区别。例如:

复制代码 代码如下:
#define INT int * INT p1, p2; // p1是指针,p2是一个int变量 typedef int * INT; INT p1, p2; // p1, p2都为指针 //--------------------------------------------------- #define LONG long unsigned LONG v1; // v1是一个无符号的long变量 typedef long LONG; unsigned LONG v1; // 错误哦~~~ 
 

相关文章

  • 关于STL的erase()陷阱-迭代器失效问题的总结

    关于STL的erase()陷阱-迭代器失效问题的总结

    下面小编就为大家带来一篇关于STL的erase()陷阱-迭代器失效问题的总结。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-12-12
  • C++实现LeetCode(34.在有序数组中查找元素的第一个和最后一个位置)

    C++实现LeetCode(34.在有序数组中查找元素的第一个和最后一个位置)

    这篇文章主要介绍了C++实现LeetCode(34.在有序数组中查找元素的第一个和最后一个位置),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-07-07
  • C语言break和continue的语句用法

    C语言break和continue的语句用法

    这篇文章主要介绍了C语言break和continue的语句用法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-04-04
  • 数据结构之红黑树详解

    数据结构之红黑树详解

    这篇文章主要介绍了数据结构之红黑树详解,红黑树是一种自平衡二叉查找树,它的统计性能要好于平衡二叉树(AVL树),因此,红黑树在很多地方都有应用,需要的朋友可以参考下
    2014-08-08
  • C/C++产生随机数函数简单介绍

    C/C++产生随机数函数简单介绍

    这篇文章主要为大家详细介绍了C/C++产生随机数函数的实现方法,如何使用C/C++产生随机数函数,感兴趣的小伙伴们可以参考一下
    2016-04-04
  • C/C++中一次性执行多个DOS命令的实现思路

    C/C++中一次性执行多个DOS命令的实现思路

    在C语言中执行DOS命令的方法很多,在这就不一给大家一一介绍了,本文重点给大家介绍C/C++中一次性执行多个DOS命令的实现思路,需要的朋友参考下
    2017-12-12
  • 基于C语言实现简单的扫雷小游戏

    基于C语言实现简单的扫雷小游戏

    这篇文章主要为大家详细介绍了基于C语言实现简单的扫雷小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-11-11
  • C语言详解链式队列与循环队列的实现

    C语言详解链式队列与循环队列的实现

    队列(Queue)与栈一样,是一种线性存储结构,它具有如下特点:队列中的数据元素遵循“先进先出”(First In First Out)的原则,简称FIFO结构。在队尾添加元素,在队头删除元素,本篇来讲解链式队列与循环队列的实现
    2022-04-04
  • C++小知识:用合适的工具来分析你的代码

    C++小知识:用合适的工具来分析你的代码

    今天小编就为大家分享一篇关于C++小知识:用合适的工具来分析你的代码,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01
  • C语言实现简单的三子棋项目

    C语言实现简单的三子棋项目

    这篇文章主要为大家详细介绍了C语言实现简单的三子棋项目,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-08-08

最新评论