宏的一些作用,包括但不限于这些

  1. 定义一个变量、字符串、类型
  2. 定义一个函数、条件表达式
  3. 条件编译、调试信息,异常类
  4. 定义结构体、命名空间
  5. 定义模版、枚举、函数对象

#define宏定义在C++中用于定义常量、函数、条件编译、字符串、条件表达式、变量、注释、调试信息、类型、函数等,下面是一些#define宏定义的用法举例:

需要注意的是,#define宏定义是一种文本替换,它不会进行类型检查和语法检查,容易出现错误。因此,在使用#define宏定义时,应该遵循一些规范,例如使用大写字母来表示常量、使用括号来保证优先级等。同时,应该避免滥用#define宏定义,以免影响代码的可读性和可维护性。

条件编译

#define DEBUG
#ifdef DEBUG
// 调试代码
#endif

这里定义了一个名为DEBUG的宏,它用于控制调试代码的编译。在程序中,可以使用#ifdef#endif来判断是否定义了DEBUG宏,例如:

#ifdef DEBUG
// 调试代码
#endif

这里的调试代码只有在定义了DEBUG宏的情况下才会被编译。

宏定义类型

#define INT_PTR int*

这里定义了一个名为INT_PTR的宏,它用于定义指向整型的指针类型。在程序中,可以使用INT_PTR来代替int*,例如:

INT_PTR p = new int;

这里定义了一个名为p的指针,它指向一个整型变量。

宏定义字符串

#define STR "Hello, world!"

这里定义了一个名为STR的字符串常量,它的值为"Hello, world!"。在程序中,可以使用STR来代替"Hello, world!",例如:

cout << STR << endl;

这里输出了"Hello, world!"。

## 宏定义变量

#define N 10
int a[N];

这里定义了一个名为N的常量,它的值为10。在程序中,可以使用N来代替10,例如:

int a[N];

这里定义了一个长度为10的整型数组a

宏定义条件表达式

#define MAX(x, y) ((x) > (y) ? (x) : (y))

这里定义了一个名为MAX的宏,它接受两个参数xy,并返回它们中的最大值。在程序中,可以使用MAX(a, b)来代替(a) > (b) ? (a) : (b),例如:

int a = 1, b = 2;
int c = MAX(a, b);

这里定义了一个整型变量c,它的值为MAX(a, b),即2。

宏定义函数

在C++中,可以使用#define宏定义来定义一个函数,但是这种方式并不是真正的函数定义,而是一种宏替换。宏定义的函数不会被编译器检查和优化,也不会进行类型检查,因此容易出现错误。因此,不建议使用#define宏定义来定义函数。

下面是一个使用#define宏定义来定义函数的示例:

#define ADD(x, y) ((x) + (y))

int main() {
int a = 1, b = 2;
int c = ADD(a, b);
return 0;
}

这里使用#define宏定义了一个名为ADD的函数,它接受两个参数xy,并返回它们的和。在程序中,可以使用ADD(a, b)来代替a + b,例如:

int c = ADD(a, b);

这里定义了一个整型变量c,它的值为a + b,即3。

需要注意的是,使用#define宏定义来定义函数容易出现错误,例如:

int c = ADD(a++, b++);

这里使用ADD(a++, b++)来代替a++ + b++,但是由于ADD是一个宏定义,它会被替换为((a++) + (b++)),导致ab的值不是预期的值。因此,不建议使用#define宏定义来定义函数,而是应该使用真正的函数定义。

宏定义调试信息

#define DEBUG_PRINT(x) cout << #x << " = " << x << endl

这里定义了一个名为DEBUG_PRINT的宏,它用于输出调试信息。在程序中,可以使用DEBUG_PRINT(a)来代替cout << "a" << " = " << a << endl,例如:

int a = 1;
DEBUG_PRINT(a);

这里输出了"a = 1",用于调试程序。

宏定义结构体

#define POINT struct { int x; int y; }

这里定义了一个名为POINT的宏,它用于定义一个简单的二维坐标结构体。在程序中,可以使用POINT来代替struct { int x; int y; },例如:

POINT p = { 1, 2 };

这里定义了一个名为p的结构体变量,它包含两个整型成员xy,分别为1和2。

宏定义命名空间

#define NS_BEGIN(name) namespace name {
#define NS_END }

这里定义了一个名为NS_BEGINNS_END的宏,它们用于定义命名空间。在程序中,可以使用NS_BEGIN(name)NS_END来代替namespace name {},例如:

NS_BEGIN(my_namespace)
int a = 1;
NS_END

这里定义了一个名为my_namespace的命名空间,它包含一个整型变量a,其值为1。

宏定义模板

#define TEMPLATE_T template<typename T>

这里定义了一个名为TEMPLATE_T的宏,它用于定义模板。在程序中,可以使用TEMPLATE_T来代替template<typename T>,例如:

TEMPLATE_T
void swap(T& a, T& b) {
T temp = a;
a = b;
b = temp;
}

这里定义了一个名为swap的模板函数,它用于交换两个变量的值。

宏定义异常类

#define EXCEPTION(name, message) class name : public std::exception { \
public: \
const char* what() const noexcept override { \
return message; \
} \
}

这里定义了一个名为EXCEPTION的宏,它用于定义异常类。在程序中,可以使用EXCEPTION(name, message)来代替class name : public std::exception { ... },例如:

EXCEPTION(MyException, "This is my exception.");

这里定义了一个名为MyException的异常类,它继承自std::exception,并重载了what()函数,返回一个字符串表示异常信息。

宏定义枚举

#define ENUM(name, ...) enum name { __VA_ARGS__ }

这里定义了一个名为ENUM的宏,它用于定义枚举。在程序中,可以使用ENUM(name, ...)来代替enum name { ... },例如:

ENUM(Color, Red, Green, Blue);

这里定义了一个名为Color的枚举,它包含三个枚举值RedGreenBlue

c++中的宏#define用途的更多相关文章

  1. C/C++中慎用宏(#define)

    宏的定义在程序中是非常有用的,但是使用不当,就会给自身造成很大的困扰.通常这种困扰为:宏使用在计算方面. 本例子主要是在宏的计算方面,很多时候,大家都知道定义一个计算的宏,对于编译和编程是多么的有用. ...

  2. c++中的宏 #define _CLASSDEF(name) class name

    #include <iostream> using namespace std; #define _CLASSDEF(name) class name; \ typedef name * ...

  3. C语言中的宏定义

    目录(?)[-] 简单宏定义 带参数的宏 运算符 运算符 宏的通用属性 宏定义中圆括号 创建较长的宏 较长的宏中的逗号运算符 宏定义中的do-while循环do 空操作的定义 预定义宏 C语言中常用的 ...

  4. C中的宏

    1. 简单宏定义 简单的宏定义有如下格式: [#define指令(简单的宏)] #define  标识符替换列表 替换列表是一系列的C语言记号,包括标识符.关键字.数.字符常量.字符串字面量.运算符和 ...

  5. 20个C语言中常用宏定义总结

    01: 防止一个头文件被重复包含 #ifndef COMDEF_H#define COMDEF_H//头文件内容#endif 02: 重新定义一些类型防止由于各种平台和编译器的不同,而产生的类型字节数 ...

  6. Android.mk中添加宏定义

    在Boardconfig.mk 中添加一个 IS_FLAG := true 由于Boardconfig.mk和各目录的Android.mk是相互关联的 所以我们可以在Android.mk 中添加 一个 ...

  7. 头文件中的#ifndef/#define/#endif 的作用

    在一个大的软件工程里面,可能会有多个文件同时包含一个头文件,当这些文件编译链接成一个可执行文件时,就会出现大量重定义的错误.在头文件中实用#ifndef #define #endif能避免头文件的重定 ...

  8. 26.怎样在Swift中定义宏?

    Swift 中没有宏定义,苹果建议使用let 或者 get 属性来替代宏定义值.虽然没有#define,但我们仍然可以使用 #if 并配合编译的配置来完成条件编译.下面会列出Swift项目开发中的一些 ...

  9. IOS中利用宏将RGB值转换为UIColor(转)

    可以在pch文件中定义宏,这样整个项目就都可以用了! #define UIColorFromRGBValue(rgbValue) [UIColor colorWithRed:((float)((rgb ...

  10. Linux中_ALIGN宏背后的原理——内存对齐

    转载自: http://englishman2008.blog.163.com/blog/static/2801290720114210254690/ 1. 原理    int a;     int ...

随机推荐

  1. StampedLock:高并发场景下一种比读写锁更快的锁

    摘要:在读多写少的环境中,有没有一种比ReadWriteLock更快的锁呢?有,那就是JDK1.8中新增的StampedLock! 本文分享自华为云社区<[高并发]高并发场景下一种比读写锁更快的 ...

  2. .Net Aspose.Words 生成Word文档

    .Net Aspose.Words 生成Word文档 在开发WinForm项目中,有一需求要生成Word文档,百度学习,记录一下实现方法 NuGet包,找到 Aspose.Words 安装 21.8. ...

  3. nodejs使用eggjs创建项目,接入influxdb完成单表增删改查

    转载请注明出处: 1.Eggjs 特性: Eggjs 是 Node.js 服务端应用开发框架,它提供了一套约定,使开发者能够快速搭建.开发和部署应用.以下是 Egg.js 的一些特性和作用: 框架内置 ...

  4. 可以,很强,68行代码实现Bean的异步初始化,粘过去就能用。

    你好呀,我是歪歪. 前两天在看 SOFABoot 的时候,看到一个让我眼前一亮的东西,来给大家盘一下. SOFABoot,你可能不眼熟,但是没关系,本文也不是给你讲这个东西的,你就认为它是 Sprin ...

  5. SQL Server 2008/2012 完整数据库备份+差异备份+事务日志备份 数据库完整还原(一)

    还原方案 数据库级(数据库完整还原) 还原和恢复整个数据库.数据库在还原和恢复操作期间会处于离线状态.SQL SERVER不允许用户备份或还原单个表.还原方案是指从一个或多个备份中还原数据.继而恢复数 ...

  6. 分布式数据库 Join 查询设计与实现浅析

    相对于单例数据库的查询操作,分布式数据查询会有很多技术难题. 本文记录 Mysql 分库分表 和 Elasticsearch Join 查询的实现思路,了解分布式场景数据处理的设计方案. 文章从常用的 ...

  7. JS异步解决方案及优缺点

    1. 回调函数 优点: 解决了同步的问题(只要有一个任务耗时长后面的任务都会等待,会拖延程序执行) 缺点: 回调地狱  不能用try  catch捕获  不能用 return setTimeout(( ...

  8. Redis数据结构:高频面试题及解析

    概述 Redis 是速度非常快的非关系型(NoSQL)内存键值数据库,可以存储键和五种不同类型的值之间的映射. 键的类型只能为字符串,值支持五种数据类型:字符串.列表.集合.散列表.有序集合. Red ...

  9. JS逆向实战19——通杀webpack逆向

    声明 本文章中所有内容仅供学习交流,抓包内容.敏感网址.数据接口均已做脱敏处理,严禁用于商业用途和非法用途,否则由此产生的一切后果均与作者无关,若有侵权,请联系我立即删除! 网站 aHR0cHM6Ly ...

  10. 1.1 熟悉x64dbg调试器

    x64dbg 是一款开源.免费.功能强大的动态反汇编调试器,它能够在Windows平台上进行应用程序的反汇编.调试和分析工作.与传统的调试器如Ollydbg相比,x64dbg调试器的出现填补了Olly ...