const与#define的区别

来源:互联网 发布:spss22医学数据分析 编辑:程序博客网 时间:2024/04/25 13:07

const是一个关键字,const修饰的内容不可改变。宏不仅可以用来代替常数值,还可以用来代替表达式,甚至是代码段

二者区别

const常量有数据类型,而宏常量没有数据类型。编译器可以对前者进行类型安全检查。而对后者只进行字符替换,没有类型安全检查,并且在字符替换可能会产生意料不到的错误(边际效应)。 有些集成化的调试工具可以对const常量进行调试,但是不能对宏常量进行调试。建议使用const常量而不使用宏常量。

(1) 编译器处理方式不同:

 define宏是在预处理阶段展开。

 const常量是编译运行阶段使用。


(2) 类型和安全检查不同

 define宏没有类型,不做任何类型检查,仅仅是展开。

 const常量有具体的类型,在编译阶段会执行类型检查。


(3) 存储不同:

define宏仅仅是展开,有多少地方使用,就展开多少次,不会分配内存。const常量会在内存中分配(可以是堆中也可以是栈中)。

const  可以节省空间,避免不必要的内存分配。 例如: 

  #define PI 3.14159 //常量宏 

  const doulbe Pi=3.14159; //此时并未将Pi放入ROM中 ...... 

  double i=Pi; //此时为Pi分配内存,以后不再分配! 

  double I=PI; //编译期间进行宏替换,分配内存 

  double j=Pi; //没有内存分配 

  double J=PI; //再进行宏替换,又一次分配内存! 

const定义常量从汇编的角度来看,只是给出了对应的内存地址,而不是象#define一样给出的是立即数,所以,const定义的常量在程序运行过程中只有一份拷贝,而 #define定义的常量在内存中有若干个拷贝。


(4) 提高了效率。 编译器通常不为普通const常量分配存储空间,而是将它们保存在符号表中,这使得它成为一个编译期间的常量,没有了存储与读内存的操作,使得它的效率也很高。

 

const小结:

1.     const修饰变量:必须初始化且不可再改变。


2.     const修饰成员变量:只能在初始化列表初始化


3.     const修饰参数:传递过来的参数在函数内不可以改变,增强健壮性。


4.     const修饰函数返回值:该返回值的内容不允许被改动


5.     const修饰成员函数:说明其不会修改数据成员。任何不会修改数据成员的函数都应该声明为const 类型。如果在编写const 成员函数时,不慎修改了数据成员,或者调用了其它非const 成员函数,编译器将指出错误,这无疑会提高程序的健壮性。


6.     const修饰指针:const int *a=&b; int const *a=&b;这两种情况const位于*左侧,const用来修饰指针所指向的变量,即*a不能改变; int * const a=&b;const位于*右侧,修饰指针本身,即a不能改变; constint * const a=&b;指针本身和指向内容均为常量。

0 0
原创粉丝点击