35.【C/C++ 枚举(bool)类型和宏定义 (超详细)】(一)

简介: 35.【C/C++ 枚举(bool)类型和宏定义 (超详细)】

(一)、宏定义

1.什么是宏定义?

1)#define 叫做宏定义命令它也是C语言预处理命令的一种,所谓宏定义,就是用一个标识符来表示一个字符串。如果在后面的代码中出现了该标识符,那么就全部替换成指定的字符串。

2)#define N 100 就是宏定义,N为宏名100是宏的内容(宏所表示的字符串)。在预处理阶段,对程序中所有出现的“宏名”,预处理器都会用宏定义中的字符串区代换,这称为“宏替换”或“宏展开”

宏定义是由源程序中的宏定义命令** define完成**的,宏替换是由预处理程序完成的。

2.宏定义的格式:

#define        宏名 字符串

1)#表示这是一条预处理命令,所有的预处理命令都以 # 开头宏名是标识符的一种,命名规则和变量相同。字符串可以是数字、表达式、if语句、函数等。

2)这里所说的字符串是一般意义上的字符序列,不要和C语言中的字符串等同,它不需要双引号

3)程序中反复使用的表达式就可以使用宏定义(替换方便)

3.宏定义注意事项和细节

0)宏定义实质:只替换,不计算

1)宏定义是用宏名来表示一个字符串,在宏展开时又以该字符串取代宏名,这只是一种简单的替换。字符串中可以包含任何字符,它可以是常数、表达式、if语句、函数等预处理程序对它不作任何检查,如有错误,只能在编译已被宏展开后的源程序时发现

2)宏定义不是说明或语句,在行末不必加分号如果加上分号则连分号一起替换

代码演示:
#include <iostream>
using namespace std;
#define PI 3.14;      //设置竑名的值位3.14
int main()
{
  cout << PI    //输出3.14
  cout << PI << endl;   //会报错,
  return 0;
}
效果展示:

3)宏定义必须写在函数之外,其作用域为宏定义命令起到源程序结束。如要终止其作用域可使用#undef命令

代码演示:
#include <iostream>
using namespace std;
#define PI 3.14       //设置竑名的值位3.14
int main()
{
  cout << PI << endl;   //输出3.14
  #undef PI    //取消宏定义 PI 
  //cout << PI << endl;   //会报错,显示未识别标识符PI
  return 0;
}
效果展示:

4)代码中的宏名如果被引号包围,那么预处理程序不对其作宏代替

代码展示:
#include <iostream>
using namespace std;
#define PI 3.14       //设置竑名的值位3.14
int main()
{
  cout << "PI=" << PI << endl;   //输出3.14
  return 0;
}
效果展示:

5)宏定义允许嵌套,在宏定义的字符串中可以使用已经定义的宏名,在宏展开时由预处理程序层层代换

代码展示:
#include <iostream>
using namespace std;
#define PI 3.14      
#define S  PI*2        //  嵌套PI
int main()
{
  cout << "PI=" << PI << endl;   //输出3.14
  cout << "S=" << S << endl;
  return 0;
}
效果展示:

6)习惯上宏名用大写字母表示,以便于与变量区别。但也允许用小写字母

7)可用宏定义表示数据类型,使书写方便

代码展示:
#include <iostream>
using namespace std;
#define PI int      
int main()
{
  PI a = 3;
  cout << "a=" << a << endl;
  return 0;
}
效果展示:

8.typedef与define 的区别

8)宏定义表示数据类型和用typedef定义数据说明符的区别宏定义只是简单的字符串替换,由预处理器来处理;而typedef 是在编译阶段由编译器处理的它并不是简单的字符串替换,而给原有的数据类型起一个新的名字,将它作为一种新的数据类型。

typedef定义格式:

typedef  替换目标   代替者
代码展示:
#include <iostream>
using namespace std;
#define PI int      
int main()
{
  typedef double s;     //定义
  PI a = 3;
  cout << "a=" << a << endl;
  s  b = 2.3;
  cout << "b=" << b << endl;
  return 0;
}
效果展示:


相关文章
|
6月前
|
C语言 C++
【实战指南】 C/C++ 枚举转字符串实现
本文介绍了在C/C++中实现枚举转字符串的实用技巧,通过宏定义与统一管理枚举名,提升代码调试效率并减少维护错误。
399 62
|
7月前
|
存储 算法 安全
c++模板进阶操作——非类型模板参数、模板的特化以及模板的分离编译
在 C++ 中,仿函数(Functor)是指重载了函数调用运算符()的对象。仿函数可以像普通函数一样被调用,但它们实际上是对象,可以携带状态并具有更多功能。与普通函数相比,仿函数具有更强的灵活性和可扩展性。仿函数通常通过定义一个包含operator()的类来实现。public:// 重载函数调用运算符Add add;// 创建 Add 类的对象// 使用仿函数return 0;
244 0
|
存储 编译器 程序员
C++类型参数化
【10月更文挑战第1天】在 C++ 中,模板是实现类型参数化的主要工具,用于编写能处理多种数据类型的代码。模板分为函数模板和类模板。函数模板以 `template` 关键字定义,允许使用任意类型参数 `T`,并在调用时自动推导具体类型。类模板则定义泛型类,如动态数组,可在实例化时指定具体类型。模板还支持特化,为特定类型提供定制实现。模板在编译时实例化,需放置在头文件中以确保编译器可见。
181 11
|
安全 程序员 C语言
C++(四)类型强转
本文详细介绍了C++中的四种类型强制转换:`static_cast`、`reinterpret_cast`、`const_cast`和`dynamic_cast`。每种转换都有其特定用途和适用场景,如`static_cast`用于相关类型间的显式转换,`reinterpret_cast`用于低层内存布局操作,`const_cast`用于添加或移除`const`限定符,而`dynamic_cast`则用于运行时的类型检查和转换。通过具体示例展示了如何正确使用这四种转换操作符,帮助开发者更好地理解和掌握C++中的类型转换机制。
|
C++
使用 QML 类型系统注册 C++ 类型
使用 QML 类型系统注册 C++ 类型
560 0
|
存储 C++
【C/C++学习笔记】string 类型的输入操作符和 getline 函数分别如何处理空白字符
【C/C++学习笔记】string 类型的输入操作符和 getline 函数分别如何处理空白字符
250 0
|
设计模式 安全 IDE
C++从静态类型到单例模式
C++从静态类型到单例模式
152 0
|
11月前
|
编译器 C++ 开发者
【C++篇】深度解析类与对象(下)
在上一篇博客中,我们学习了C++的基础类与对象概念,包括类的定义、对象的使用和构造函数的作用。在这一篇,我们将深入探讨C++类的一些重要特性,如构造函数的高级用法、类型转换、static成员、友元、内部类、匿名对象,以及对象拷贝优化等。这些内容可以帮助你更好地理解和应用面向对象编程的核心理念,提升代码的健壮性、灵活性和可维护性。
|
9月前
|
编译器 C++ 容器
【c++11】c++11新特性(上)(列表初始化、右值引用和移动语义、类的新默认成员函数、lambda表达式)
C++11为C++带来了革命性变化,引入了列表初始化、右值引用、移动语义、类的新默认成员函数和lambda表达式等特性。列表初始化统一了对象初始化方式,initializer_list简化了容器多元素初始化;右值引用和移动语义优化了资源管理,减少拷贝开销;类新增移动构造和移动赋值函数提升性能;lambda表达式提供匿名函数对象,增强代码简洁性和灵活性。这些特性共同推动了现代C++编程的发展,提升了开发效率与程序性能。
356 12
|
7月前
|
人工智能 机器人 编译器
c++模板初阶----函数模板与类模板
class 类模板名private://类内成员声明class Apublic:A(T val):a(val){}private:T a;return 0;运行结果:注意:类模板中的成员函数若是放在类外定义时,需要加模板参数列表。return 0;
194 0