C语言详细分析宏定义的使用

 更新时间:2022年04月21日 11:01:28   作者:清风自在 流水潺潺  
宏定义是用宏名来表示一个字符串,在宏展开时又以该字符串取代宏名,这只是一种简单的替换。字符串中可以含任何字符,可以是常数,也可以是表达式,预处理程序对它不作任何检查,如有错误,只能在编译已被宏展开后的源程序时发现

一、C语言中函数的“缺陷”

实参和形参之间仅仅是值传递,因此,函数中无法直接改变实参。

二、再次理解函数

函数是一种代码复用的手段

  • 把实现某个功能的代码片段进行封装(当作一个整体)
  • 给这个代码片段一个合适的名字(通过名字使用代码)
  • 定义参数(定义代码片段需要处理的问题)

三、C语言中的宏

  • 宏是C语言中代码复用的补充方式
  • 宏定义语法:#define MACRO(param) code_segment
  • 宏使用语法:MACRO(num);

例如:

#define ADD(a,b) a + b
int main()
{
    int z = ADD(1,2);
    printf("z = %d\n", z);
    return 0;
}

四、宏与函数的不同

  • 宏不是函数,使用宏没有函数调用的过程
  • 函数调用先传递参数值,然后跳转执行函数体,最后返回
  • 使用宏只是单纯“代码复制粘贴”,然后替换参数
  • 同一个函数,无论调用多少次,都执行相同的函数体代码
  • 同一个宏,每次使用都会“复制粘贴”相同代码

五、编译器组成简介

  • 预处理模块:处理所有宏以及#开头的语句(复制粘贴替换)
  • 编译模块:将C程序翻译成二进制程序
  • 链接模块:将二进制程序组合成可执行程序

六、宏使用示例

用一个简单的交换两个数的值作为例子:

#include <stdio.h>
#define SWAP(a, b)  {int t = a; a = b; b = t;}
int main()
{
    int x = 1;
    int y = 2;
    SWAP(x, y);   // {int t = x; x = y; y = t;}
    printf("x = %d, y = %d\n", x, y);
    return 0;
}

下面为输出结果:

七、再论宏常量

#define NAME value

  • 预处理模块将代码中出现的NAME标识符替换为value
  • 因此,宏常量在本质上与字面量相同(真正意义的常量)

八、小结

  • 宏是C语言中代码复用的补充方式
  • 宏不是函数,使用宏没有函数调用的过程
  • 预处理模块对宏的处理方式:复制粘贴替换
  • 程序中使用宏的地方最终被处理为对应的代码片段
  • 宏常量的本质就是字面量

到此这篇关于C语言详细分析宏定义的使用的文章就介绍到这了,更多相关C语言宏定义内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C++递归实现螺旋数组的实例代码

    C++递归实现螺旋数组的实例代码

    这篇文章主要介绍了C++递归实现螺旋数组的实例代码,代码简单易懂,非常不错,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-04-04
  • C语言学习之条件和 if...else语句详解

    C语言学习之条件和 if...else语句详解

    这篇文章主要给大家介绍了C语言中的条件和 if...else语句,文中通过代码示例给大家介绍的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下
    2023-12-12
  • C语言实现堆排序的简单实例

    C语言实现堆排序的简单实例

    这篇文章主要介绍了C语言实现堆排序的简单实例,讲述了堆排序的原理,需要的朋友可以参考下
    2014-07-07
  • C语言 链式二叉树结构详解原理

    C语言 链式二叉树结构详解原理

    二叉树的链式存储结构是指,用链表来表示一棵二叉树,即用链来指示元素的逻辑关系。通常的方法是链表中每个结点由三个域组成,数据域和左右指针域,左右指针分别用来给出该结点左孩子和右孩子所在的链结点的存储地址
    2021-11-11
  • C语言超市管理系统设计

    C语言超市管理系统设计

    这篇文章主要为大家详细介绍了C语言超市管理系统设计,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-02-02
  • C++图论之Bellman-Ford算法和SPFA算法的实现

    C++图论之Bellman-Ford算法和SPFA算法的实现

    贝尔曼-福特算法(Bellman-Ford)是由理查德·贝尔曼和莱斯特·福特创立的,求解单源最短路径问题的一种算法。SPFA 算法是 Bellman-Ford算法 的队列优化算法的别称,通常用于求含负权边的单源最短路径。本文将详解两个算法的实现,需要的可以参考一下
    2022-06-06
  • C++ OpenCV实战之手写数字识别

    C++ OpenCV实战之手写数字识别

    这篇文章主要为大家详细介绍了如何使用machine learning机器学习模块进行手写数字识别功能,文中的示例代码讲解详细,感兴趣的可以了解一下
    2022-08-08
  • C语言顺序查找算法介绍及示例

    C语言顺序查找算法介绍及示例

    顺序查找又称线性查找,主要用于在线性表中进行查找。顺序查找通常分为对一般的无序线性表的顺序查找和对按关键字有序的顺序表的顺序查找,下面我们来一探究竟
    2022-08-08
  • 使用C++和Crypto++库实现AES加密与解密

    使用C++和Crypto++库实现AES加密与解密

    在这篇博客中,我们将深入探讨如何利用C++和Crypto++库实现高效且安全的AES加密与解密机制,Crypto++是一款高度认可的免费C++类库,文中通过代码示例介绍的非常详细,具有一定的参考价值,需要的朋友可以参考下
    2024-01-01
  • C语言实现2048小游戏

    C语言实现2048小游戏

    这篇文章主要为大家详细介绍了C语言实现2048小游戏,注释清晰,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-05-05

最新评论