C++中const与#define的利弊分析

 更新时间:2018年05月02日 08:41:07   作者:灵感编程  
C++中不但可以用define定义常量还可以用const定义常量,下面这篇文章主要给大家分析介绍了关于C++中const与#define的利弊,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

C++中const与#define的区别如下:

用#define MAX 255定义的常量是没有类型的,所给出的是一个立即数,编译器只是把所定义的常量值与所定义的常量的名字联系起来,define所定义的宏变量在预处理的时候进行替换,在程序中使用到该常量的地方都要进行拷贝替换;

用const float MAX = 255; 定义的常量有类型名字,存放在内存的静态区域中,在程序运行过程中const变量只有一个拷贝,而#define 所定义的宏变量却有多个拷贝,所以宏定义在程序运行过程中所消耗的内存要比const变量的大得多;

用define定义的常量是不可以用指针变量去指向的,用const定义的常量是可以用指针去指向该常量的地址的;

用define可以定义一些简单的函数,const是不可以定义函数的.

const和#define的利弊,从而推导const的意义;

const和#define都有类似的功能,那就是定义一个“常量”;

想用来替换#define定义常量这种方式。这是一种定义宏的方式。因为宏替换定义常量有一定的缺陷:不做类型检查,没有作用域限制(这样很容易被后续污染)。

#include#includeusingnamespacestd;voidmyfunc1(){#definea 10}voidmyfunc2(){printf("a=%d\n", a);}intmain(){printf("外面打印:a=%d\n", a);myfunc1();myfunc2();system("pause");return0;}


因为只做字面上的直接替换,全局都有效,所以无论定义在哪里,全局都可以访问。因为是在预编译的时候就替换好了(只要有定义,就在预编译的时候进行全程替换,所以外面里面都可以访问)。

同时,很容易受到污染。

#include#includeusingnamespacestd;#definea 10voidmyfunc1(){#definea 20printf("myfunc1里面的:a=%d\n", a);}voidmyfunc2(){printf("myfunc2里面的:a=%d\n", a);}intmain(){printf("外面打印:a=%d\n", a);myfunc1();myfunc2();system("pause");return0;}

提示有宏重定义,结果全部都改变为新的:


宏的方式相当于全局变量,无论在函数里还是函数外命名的时候都要精心雕琢(有点头痛),否则很容易在以后新的函数中不小心被替换掉,这就是为什么用它定义常量都基本上全部大写,而变量都弄成小写,这样既然不记得有多少宏名了,也不至于冲突。但是它的全局性还是没有解决。

而const因为有作用域限制,解决了污染全局变量的困扰。

下面的程序是不行的:

#include#includeusingnamespacestd;voidmyfunc1(){constinta =20;printf("myfunc1里面的:a=%d\n", a);}voidmyfunc2(){printf("myfunc2里面的:a=%d\n", a);}intmain(){printf("外面打印:a=%d\n", a);myfunc1();myfunc2();system("pause");return0;}


定义个全局的只读变量:

#include#includeusingnamespacestd;constinta =10;voidmyfunc1(){constinta =20;printf("myfunc1里面的:a=%d\n", a);}voidmyfunc2(){printf("myfunc2里面的:a=%d\n", a);}intmain(){printf("外面打印:a=%d\n", a);myfunc1();myfunc2();system("pause");return0;}


里面的既不干扰外面的,还可以有优先级之分,同时要做全局也可以做全局。

这样新做的函数中要想使用a这个名字了,不用考虑什么,直接用就是了。不会影响以前外面定义的全局变量a,是不是省事的多啊。

const是只读变量,本质上还是变量,是变量就可以传递参数,而const还做类型检查,所以好处更多,如:做形参,可以接收不同的参数,更灵活。

你不能在里面把我的变量给改了吧,可以传递不同的变量,因此就晓得更灵活了;

#include#includeusingnamespacestd;voidmyfunc1(constintk){printf("myfunc1里面的数据=%d\n", k);}intmain(){constinta =20;myfunc1(a);constintb =30;myfunc1(b);system("pause");return0;}


const的应用:

由于是只读变量,因此保护了外面的实参,外面传递实参进来,在函数体里不能修改。因此让外面的实参得到安全性考虑。

#include#includeusingnamespacestd;voidmyfunc1(constint* k){*k =3;printf("myfunc1里面的数据=%d\n", k);}intmain(){constinta =20;myfunc1(&a);system("pause");return0;}


宏替换的方式相当于弄全局变量,很容易被污染,没有作用域限制,做不了优先级区分。它是在预编译的时候就被替换了。

而const是在编译的时候才分配变量,有作用域区分,和类型一致的安全性检测,应用const来开发项目更方便灵活...

宏替换定义的是常量,必定全局有效;

const定义的是只读变量,有作用域之分,可以做全局的,也可以做局部的,还有优先级之分。既方便又安全,可以代替#define了。那为什么都存在?因为也都有好处,只是想拿各自的好处罢了:

宏替换的方式,让整个编译过程变慢(预编译时间+真正编译的时间),但是让程序运行速度变快,因为早已直接替换好了(宏展开),直接运行就得了。

const和它相反,整个编译时间少,但是程序运行速度慢点了,因为要找内存空间开辟变量...

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

相关文章

  • C++简明图解分析浅拷贝与深拷贝

    C++简明图解分析浅拷贝与深拷贝

    在c++中,深拷贝和浅拷贝也算是一个难点,特别是对于初学者来说,往往在不知道两者区别的情况下而错误的使用了浅拷贝,从而导致了野指针之类的问题,但是又因为缺少理解所以很难定位到问题所在
    2022-06-06
  • VC++实现通过API来查看程序错误信息的方法

    VC++实现通过API来查看程序错误信息的方法

    这篇文章主要介绍了VC++实现通过API来查看程序错误信息的方法,非常实用的功能,需要的朋友可以参考下
    2014-08-08
  • C++简明图解this指针的使用

    C++简明图解this指针的使用

    this 指针在C++类和对象中是个很方便实用的关键字,可以简化对象成员属性的调用,使代码表达的含义更加准确;在之前的学习中我们都可以判断变量所占内存空间大小,那么我们创建的类对象所占的内存空间怎么计算呢?想知道this的妙用和类对象占用的内存空间就来跟我学习吧
    2022-06-06
  • 深入理解C++中的vector类的用法及特性

    深入理解C++中的vector类的用法及特性

    vector直接翻译过来为向量,在C++中为封装动态数组的容器,且有序,需要的朋友可以参考下
    2016-05-05
  • 内部排序之堆排序的实现详解

    内部排序之堆排序的实现详解

    本篇文章是对堆排序的实现进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • C++浅析虚函数使用方法

    C++浅析虚函数使用方法

    对C++了解的人都应该知道虚函数(Virtual Function)是通过一张虚函数表(Virtual Table)来实现的。简称为V-Table。本文就将详细讲讲虚函数表的原理与使用,需要的可以参考一下
    2022-08-08
  • C语言中free函数的使用详解

    C语言中free函数的使用详解

    free函数是释放之前某一次malloc函数申请的空间,而且只是释放空间,并不改变指针的值。下面我们就来详细探讨下
    2017-05-05
  • C语言宏定义结合全局变量的方法实现单片机串口透传模式

    C语言宏定义结合全局变量的方法实现单片机串口透传模式

    今天小编就为大家分享一篇关于C语言宏定义结合全局变量的方法实现单片机串口透传模式,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12
  • C++ 内存分区模型的使用(代码区、全局区、栈区、堆区、new)

    C++ 内存分区模型的使用(代码区、全局区、栈区、堆区、new)

    这篇文章主要介绍了C++ 内存分区模型的使用(代码区、全局区、栈区、堆区、new),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04
  • 浅析C++中的间接宏函数

    浅析C++中的间接宏函数

    这篇文章主要介绍了C++中的间接宏函数,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-04-04

最新评论