C语言之const关键字总结

一概述:

         同样都可以定义常量,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指向的地址.

错误:



以此类推.



总结:const在谁后面就不可以修改.



猜你喜欢

转载自blog.csdn.net/null959_/article/details/80563227
今日推荐