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

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

4.带参数的宏定义:

1).基本介绍

1)C/C++允许宏带有参数。在宏定义中的参数称为“形式参数”,在宏调用中的参数为“实际参数”,这点和函数有些类似

2)对带参数的宏,在展开过程中不仅要进行字符串替换还要用实参去替换形参

3)带参宏定义的一般形式为**#define 宏名(形参列表) 字符串**,在字符串中可以含有各个形参

4)带参宏调用的一般形式为:宏名(实参列表)

代码展示:
#include <iostream>
using namespace std;
#define Max(a,b) (a>b?a:b)      //  字符串的(a>b)的小括号不能省略  
int main()
{
  int x = 3, y = 4,max;
  max= Max(x, y);     //     必须要有,不能省略 
  cout << "最大值为:" << max << endl;    //不能替换Max(x, y)  ,替换就错
  return 0;
}

说明

//1.MAX(x,y);调用带参数宏定义

//2.在宏替换时(预处理,由预处理器),会进行字符串的替换,同时会使用实参,去替换形参

//3.即MAX(x,y)宏替换后(x>y)?x:y

//1.MAX就是带参数的宏

//2.(a,b)就是形参

//3.(a>b)?a:b是带参数的宏对应字符串,该字符串可以使用形参

效果展示:

2)、带参数宏定义的注意事项和细节

1)带参数宏定义中,形参之间可以出现空格,但是宏名和形参列表之间不能有空格出现 例:

#define MAX(a,b) (a>b)?a:b如果写成了#define MAX (a,b) (a>b)?a:b将被认为是无参宏定义,宏名MAX代表字符串(a.b) (a>b)?a:b而不是:MAX(a,b) 代表(a>b)?a:b了

2)在带参宏定义中,不会为形式参数分配内存,因此不必指明数据类型。而在宏调用中,实参包含了具体的数据,要用它们去替换形参,因此实参必须要指明数据类型

3)在宏定义中,字符串内的形参通常要用括号括起来以避免出错

3)、经典举列子

运用内嵌宏定义,求圆的周长:

代码展示:
#include <iostream>
using namespace std;
#define PI 3.14
#define Quar(r)  (2*PI*r)   
int main()
{
  double r,quar;
  cout << "请您输入圆的半径:" << endl;
  cin >> r;
  quar=Quar(r);
  cout << "最大值为:" <<quar << endl;    //不能替换Max(x, y)  ,替换就错
  return 0;
}
效果展示:

(二)、枚举类型:

1.什么是枚举?

enum是计算机编程语言中的一种数据类型枚举类型:在实际问题中,有些变量的取值被限定在一个有限的范围内。例如,一个星期内只有七天,一年只有十二个月,一个班每周有六门课程等等。如果把这些量说明为整型,字符型或其它类型显然是不妥当的。为此,C语言提供了一种称为“枚举”的类型。在“枚举”类型的定义中列举出所有可能的取值,被说明为该“枚举”类型的变量取值不能超过定义的范围。应该说明的是,枚举类型是一种基本数据类型,而不是一种构造类型,因为它不能再分解为任何基本类型。

2.枚举有什么作用?

3.枚举类型的格式:

enum 枚举名{ 枚举值表 };
在枚举值表中应罗列出所有可用值。这些值也称为枚举元素。

4.枚举的注意事项:

(1)enum是关键字,标识枚举类型。定义枚举类型必须用enum开头

(2)枚举数据表中的名字是程序员自己设定,这些名字只是一个符号。但注意命名时要提高程序的可读性。枚举型是一个集合,集合中的元素(枚举成员)是一些命名的整型常量,元素之间用逗号,隔开

(3)枚举数据表的值都是整数第一个枚举成员的默认值为整型的0,后续枚举成员的值在前一个成员上加1。也可以人为设定枚举成员的值,从而自定义某个范围内的整数。

(4)可以在定义类型时对枚举常量初始化

(5)枚举类型可以进行比较

(6)枚举常量不是字符串,不能用%s方式输出字符串。

(7)枚举型是预处理指令#define的替代

比如:

#include <iostream>
using namespace std;
int main()
{
  enum status
  {
    copy,
    deldete
  };
  cout << copy << endl;
}

1.一次定义多个常量:

1.1经典用法

比如说我们的程序中处理问题时与星期几有关,可能要将星期一转换为数字1,星期二转换为数字2,一直到数字7,在不用enum关键字的情况下,可以使用define来定义,但是大家会觉得很麻烦,因为你要一个一个的定义,星期的还好说,只有7天,如果是月份呢,一年有12个月份,那就要写12个define,非常的不方面,如果利用enum的话就会非常的方便

代码展示:(起点赋值)
#include <iostream>
using namespace std;
enum status {Mon=1,Tue,Wed,Thu,Fri,Sat,Sun};
int main()
{
  cout << "星期三是:"<<Wed << endl;
}
效果展示:

这样定义以后,Mon的值为1,Tue的值为2,Wed的值为3,一次类推。然后就可以像使用define之后的常量一样的使用定义的7个值了。

如果开头不写Mon=1的话,Mon的默认值为0,然后从0开始增长。

代码展示:(中间赋值)
#include <iostream>
using namespace std;
enum status {Mon,Tue,Wed,Thu=4,Fri,Sat,Sun};
int main()
{
  cout << "星期三是:"<<Wed << endl;
}
效果展示:

2.限定变量的范围:

比如我们的应用程序中要处理有关天数的东西,显然天数只能取1-7中的某个数字,为了保证程序的正确性和健壮性,我们应该使用enum。

#include <iostream>
using namespace std;
enum status {Mon=1,Tue,Wed,Thu,Fri,Sat,Sun};
int main()
{
  enum status a = Wed;
  cout << "星期三是:"<<a << endl;
}

3.使用enum的几种用法:

(1).再定义的同时声明变量:
enum static{one,two,three,four}a,b;     //声明两个变量a,b
(2)、定义完enum之后在声明变量:
enum status {Mon=1,Tue,Wed,Thu,Fri,Sat,Sun};
enum status a = Wed;
(3)、定义匿名的枚举变量:
enum  {Mon=1,Tue,Wed,Thu,Fri,Sat,Sun}a;

这样的话只能使用a这一个枚举类型,不能再定义其他的枚举变量

(4)

typedef enum则是用来定义一个数据类型,那么该类型的变量值只能在enum定义的范围内取

typedef enum  {Jan=1,Feb,Mar,Apr,May,Jun,Jul,Aug,Sep,Oct,Nov,dec} Day;
Day a, b;

4.宏定义和enum的区别

enum用来定义一系列宏定义常量区别用,相当于一系列的#define xx xx,当然它后面的标识符也可当作一个类型标识符;typedef enum则是用来定义一个数据类型,那么该类型的变量值只能在enum定义的范围内取。两者在这点上是没有差别的。

注意:同一个程序中不能定义同名的枚举类型,不同的枚举类型中也不能存在同名的命名常量

(三)、结构体?

点击我看结构体

制作不易,谢谢支持!!!

相关文章
|
3月前
|
存储 编译器 程序员
C++类型参数化
【10月更文挑战第1天】在 C++ 中,模板是实现类型参数化的主要工具,用于编写能处理多种数据类型的代码。模板分为函数模板和类模板。函数模板以 `template` 关键字定义,允许使用任意类型参数 `T`,并在调用时自动推导具体类型。类模板则定义泛型类,如动态数组,可在实例化时指定具体类型。模板还支持特化,为特定类型提供定制实现。模板在编译时实例化,需放置在头文件中以确保编译器可见。
41 11
|
4月前
|
安全 程序员 C语言
C++(四)类型强转
本文详细介绍了C++中的四种类型强制转换:`static_cast`、`reinterpret_cast`、`const_cast`和`dynamic_cast`。每种转换都有其特定用途和适用场景,如`static_cast`用于相关类型间的显式转换,`reinterpret_cast`用于低层内存布局操作,`const_cast`用于添加或移除`const`限定符,而`dynamic_cast`则用于运行时的类型检查和转换。通过具体示例展示了如何正确使用这四种转换操作符,帮助开发者更好地理解和掌握C++中的类型转换机制。
|
5月前
|
C++
使用 QML 类型系统注册 C++ 类型
使用 QML 类型系统注册 C++ 类型
112 0
|
6月前
|
编译器 C++ 运维
开发与运维函数问题之函数的返回类型如何解决
开发与运维函数问题之函数的返回类型如何解决
43 6
|
5月前
|
存储 C++
【C/C++学习笔记】string 类型的输入操作符和 getline 函数分别如何处理空白字符
【C/C++学习笔记】string 类型的输入操作符和 getline 函数分别如何处理空白字符
56 0
|
5月前
|
设计模式 安全 IDE
C++从静态类型到单例模式
C++从静态类型到单例模式
43 0
|
6月前
|
编译器 C++
C++从遗忘到入门问题之C++中的浮点数类型问题如何解决
C++从遗忘到入门问题之C++中的浮点数类型问题如何解决
|
2月前
|
存储 编译器 C语言
【c++丨STL】string类的使用
本文介绍了C++中`string`类的基本概念及其主要接口。`string`类在C++标准库中扮演着重要角色,它提供了比C语言中字符串处理函数更丰富、安全和便捷的功能。文章详细讲解了`string`类的构造函数、赋值运算符、容量管理接口、元素访问及遍历方法、字符串修改操作、字符串运算接口、常量成员和非成员函数等内容。通过实例演示了如何使用这些接口进行字符串的创建、修改、查找和比较等操作,帮助读者更好地理解和掌握`string`类的应用。
60 2
|
2月前
|
存储 编译器 C++
【c++】类和对象(下)(取地址运算符重载、深究构造函数、类型转换、static修饰成员、友元、内部类、匿名对象)
本文介绍了C++中类和对象的高级特性,包括取地址运算符重载、构造函数的初始化列表、类型转换、static修饰成员、友元、内部类及匿名对象等内容。文章详细解释了每个概念的使用方法和注意事项,帮助读者深入了解C++面向对象编程的核心机制。
110 5
|
2月前
|
存储 编译器 C++
【c++】类和对象(中)(构造函数、析构函数、拷贝构造、赋值重载)
本文深入探讨了C++类的默认成员函数,包括构造函数、析构函数、拷贝构造函数和赋值重载。构造函数用于对象的初始化,析构函数用于对象销毁时的资源清理,拷贝构造函数用于对象的拷贝,赋值重载用于已存在对象的赋值。文章详细介绍了每个函数的特点、使用方法及注意事项,并提供了代码示例。这些默认成员函数确保了资源的正确管理和对象状态的维护。
110 4