一概述:
同样都可以定义常量,const与#define相比有什么不同?
1.const常量有数据类型,而宏常量没有数据类型。
2.编译器可以对常量进行类型安全检查,而宏只进行字符替换,没有安全检查,而且在字符替换对过程中可以发生意想不到对错误(边界效应).
#define N 2+3
double a = N/2;
我们预想a值是2.5,可实际的值3.5
3.define在编译的预处理阶段起作用,而const是在 编译、运行的时候起作用。
4.const方便代码调试,define是不能进行调试的,因为在预编译阶段就已经替换掉了。
注意:define的作用非常强大,虽然它没有类型检测,不能调试,还要考虑边界效应,但是正因为没有类型检测,预编译是就完成,才使得它的使用更加灵活,功能更加强大,如果我们可以善用define,往往可以发挥到意想不到的效果。
二.const的使用:
const意味着只读,凡是修改了const不允许修改的东西,编译器报错.
2.1.const 修饰指针(画重点,理解这个)
const修饰指针可以分为如下的四种情况:
int b =5;
const int *a = &b; //情况一
int const *a = &b; //情况二
int *const a = &b; //情况三
const int *const a = &b; //情况四
总结四种情况,只有两种情况:
1.const位于*左侧,则const修饰指针所指向的变量的'值'。即指针指向为常量.
虽然不可以修改指针a指向变量的值,但是我们可以修改指针a指向的地址。
还可以直接改变 b 的值:
重新赋值就行了 b = 7;
注意:情况一和情况二相同。
2.const位于*右侧,const就是修饰存储在指针变量里面的'地址',即指针变量本身就是常量。
情况四:就是情况1与情况3的集合体了,既不能修改指针指向变量的值,也不允许修改本身指针变量指向的地址.
三.修饰函数的参数:
1.防止修改指针指向的地址:
正确做法:不能修改指针变量p1,p2指向的地址.
错误:
以此类推.