英菲尼迪 安全吗:Const应用

来源:百度文库 编辑:偶看新闻 时间:2024/05/01 02:37:56

指针常量:即指针本身的值是不可改变的,而指针指向的变量的值是可以改变的;

常量指针:即指针指向的变量的值是不可改变的,而指针本身的值是可以改变的;

   可以这样去理解:因为指针本身也是一个变量,只不过指针存放的是地址而已,而一旦指针变成了常量,即指针本身的值是不可变的,此时指针只能指向固定的存储单元;指针一般会指向一个变量,如果该变量成为一个常量,那么该变量的值就不能被修改,即常量指针,指针指向的是一个不可变的变量。

#include

int main(void)

{

    const int a=3;

    int *pa=&a;

    *pa=4;

    printf("%d\n",*pa);

    printf("%d\n",a);

    return 0;

}


编译结果:

e:\c++\test\test.c(6) : warning C4090: 'initializing' : different 'const' qualifiers

输出结果是: 4

           4

从这里可以看出a的值被修改了,在C语言中用const去修饰整形变量a,即a的值是不可变的,不能显式地通过赋值语句去改变a的值,

但是不代表在程序中不能通过其它方法来修改这个值。

总结:(1)在C语言中用const去修饰一个变量,表示这个变量是只读的,不可通过显式的调用a去修改a的值,并且此时a仍然是一个变 量,不能等同于常量;

    (2)要注意const在声明变量时所处的位置,位置不同,在意义上可能会有很大的不同。

       如果const在'*'左边,则表示指针指向的变量的值不可变;

       如果const在'*'右边,则表示指针的值是不可变的;


C语言和C++中的const有很大区别。在C语言中用const修饰的变量仍然是一个变量;而在C++中用const修饰过后,就变成常量了。

   如:

const int n=5;
int a[n];

这种方式在C语言中会报错,原因在于声明数组时数组的长度必须为一个constant,即常量,虽然n用const限定了,但n终究是一个变量,因此会报错;

但是在C++中不会报错,因为在C++中用const修饰过后,n就已经等同于一个常量了,因此可以通过。

又如:

#includeusing namespace std;

int main(void)
{
const int a=3;
int *pa=&a;
*pa=4;
printf("%d\n",*pa);
printf("%d\n",a);
return 0;
}

编译结果:
e:\c++\acm\lianxi.cpp(7) : error C2440: 'initializing' : cannot convert from 'const int *' to 'int *'
这种情况在C++中是不允许的,原因在于a用const修饰后,已经成为常量了,因此是不允许被修改的,无论是显式的更改a的值或是通过其它方法修改它的值都是不允许的。