程序笔记   发布时间:2022-06-07  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了C++中const与#define的利弊分析大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

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

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

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

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

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

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

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

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

#include#includeusingnamespacestd;voIDMyFunc1(){#definea 10}voIDMyFunc2(){printf("a=%d\n",a);}intmain(){printf("外面打印:a=%d\n",a);MyFunc1();MyFunc2();system("pause");return0;}

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

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

同时,很容易受到污染。@H_489_5@

#include#includeusingnamespacestd;#definea 10voIDMyFunc1(){#definea 20printf("MyFunc1里面的:a=%d\n",a);}voIDMyFunc2(){printf("MyFunc2里面的:a=%d\n",a);MyFunc1();MyFunc2();system("pause");return0;}

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

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

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

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

下面的程序是不行的:@H_489_5@

#include#includeusingnamespacestd;voIDMyFunc1(){ConsTinta =20;printf("MyFunc1里面的:a=%d\n",a);MyFunc1();MyFunc2();system("pause");return0;}

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

定义个全局的只读变量:@H_489_5@

#include#includeusingnamespacestd;consTinta =10;voIDMyFunc1(){ConsTinta =20;printf("MyFunc1里面的:a=%d\n",a);MyFunc1();MyFunc2();system("pause");return0;}

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

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

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

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

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

#include#includeusingnamespacestd;voIDMyFunc1(consTintk){printf("MyFunc1里面的数据=%d\n",k);}intmain(){ConsTinta =20;MyFunc1(a);consTintb =30;MyFunc1(b);system("pause");return0;}

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

const的应用:@H_489_5@

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

#include#includeusingnamespacestd;voIDMyFunc1(consTint* k){*k =3;printf("MyFunc1里面的数据=%d\n",k);}intmain(){ConsTinta =20;MyFunc1(&a);system("pause");return0;}

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

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

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

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

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

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

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

总结@H_489_5@

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

您可能感兴趣的文章:

  • C语言编程技巧 关于const和#define的区别心得
  • c++ 尽量不要使用#define 而是用const、enum、inline替换。
  • c++ const引用与非const引用介绍
  • C++中的类型转换static_cast、dynamic_cast、const_cast和reinterpret_cast总结
  • C/C++中static,inline三种关键字详细总结
  • C++中const的实现机制深入分析
  • C/C++中宏定义(#definE)
  • C++ 中pragma once 与 #ifndef _XXX_H_ #define _XXX_H_的区别
  • C/C++中的typedef和#define详解

大佬总结

以上是大佬教程为你收集整理的C++中const与#define的利弊分析全部内容,希望文章能够帮你解决C++中const与#define的利弊分析所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。