c语言中几种情况产生const c语言有const吗

c语言中几种情况产生const?

一、修饰局部变量

const int num=5;

int const num=5;

这两种写法是一样的,都是表示变量num的值不能被改变,用const修饰变量时,一定要初始化,否则之后就不能再进行赋值了(后面会讲到一种特殊情况)。

二、修饰全局变量

全局变量的作用域是整个文件,且全局变量的生存周期为程序运行的整个过程,所以我们应该尽量避免使用全局变量,一旦某个函数改变了全局变量的值,会影响到其他引用这个变量的函数,是一个很隐蔽的操作。

三、修饰常量指针与指针常量

1.常量指针

常量指针是指针指向的内容是常量,可以有以下两种定义方式。

const int * num;

int const * num;

以下两点需要注意:

常量指针说的是不能通过这个指针改变变量的值,但可以通过其他的引用来改变变量的值。

int cnt=5;

const int* num=&cnt;

cnt=6;

常量指针指向的值不能改变,但这并不意味着指针本身不能改变,常量指针可以指向其他的地址。

int cnt=5;

int tmp=6;

const int* num=&cnt;

num=&tmp;

2.指针常量

指针常量是指指针本身是个常量,不能再指向其他的地址,写法如下:

int *const num;

需要注意的是,指针常量指向的地址不能改变,但是地址中保存的数值是可以改变的,可以通过其他指向改地址的指针来修改。

int cnt=5;

int *tmp=&cnt;

int* const num=&cnt;

*tmp=6;

区分常量指针和指针常量的关键就在于星号的位置,我们以星号为分界线。

如果const在星号的左边,则为常量指针;如果const在星号的右边则为指针常量。

如果我们将星号读作‘指针’,将const读作‘常量’的话,内容正好符合。

int const * num;是常量指针,

int *const num;是指针常量。

3.指向常量的常指针

还有一种情况是指向常量的常指针,这相当于是常量指针与指针常量的结合,指针指向的位置不能改变并且也不能通过这个指针改变变量的值,例如

const int* const num;

这个代表num所指向的对象的值以及它的地址本身都不能被改变。

四、修饰函数的形参

根据常量指针与指针常量,const修饰函数的参数也是分为三种情况

1.防止修改指针指向的内容

void FUN(char *destin, const char *source);

其中 source 是输入参数,destin 是输出参数。给 source 加上 const 修饰后,如果函数体内的语句试图改动 source 的内容,编译器将报错,但反过来是可以的,编译器允许将char *类型的数据赋值给const char *类型的变量。

2.防止修改指针指向的地址

void FUN ( int * const p1 , int * const p2 )

指针p1和指针p2指向的地址都不能修改。

3.以上两种的结合。

五、修饰函数的返回值

如果给以“指针传递”方式的函数返回值加 const 修饰,那么函数返回值(即指针)的内容不能被修改,该返回值只能被赋给加const 修饰的同类型指针。

延伸阅读

const常量可以多次赋值吗?

不能多次赋值。

1.const常量只能在声明定义时候进行赋值,即是其定义时必须初始化。

2.用 const 修饰的变量,无论是全局变量还是局部变量,生存周期都是程序运行的整个过程,因为用 const 修饰过的局部变量就有了静态特性。

3.懂得区分常量指针与指针常量的区别。常量指针说的是不能通过这个指针改变变量的值,但是还是可以通过其他的引用来改变变量的值的,指针常量是指指针本身是个常量,不能在指向其他的地址。

C语言中的二维数组名是一个二重指针吗?

1、二维数组名不是二级指针,它只是一个比较特殊的常量指针。包括三维,四维,乃至N维数组也是如此。只要是数组,那么它就是一个普通的常量指针。2、二级指针p也可以解释为指针的指针,即p内保存的值实际上还是一个指针,计算:*p的值实际上是一个指针值,那么 *(*p)即二级指针指向的最终值。对于二维数组a[2][2],a也是一个地址,并且这个值也等于a[0],也等于a[0[0]的地址,即&a[0][0],由此看来对a取地址的值是一个变量值(不是指针),所以a并不是一个二级指针,最多算一个一级指针。

c++ *next是什么指针?

是常量指针。

譬如,char * const *(*next)()

next是一个指针,指向一个函数。这个函数接受的参数为空,返回的参数为一个指针,它指向的对象是一个指向char的常量指针。

即:declare next as pointer to function returning pointer to const pointer to char。

程序中的每个函数都位于内存中的某个位置,所以存在着指向那个位置的指针。

指针常量为什么不能指向标识常量?

你这里的标识常量应该是指符号常量吧(比如constintc=10;中的c)。指针常量所指向的地址是不可以改变的,但所指向的单元内容可以改变,而符号常量的内容是不能改变的。如果允许指针常量指向符号常量,就违背了设置指针常量的意图。

为什么常量指针可以不初始化?

不是的。

常量指针必须初始化,常量指针必须在定义时就初始化,否则系统是会报错的。

常量指针的指向地址是不允许进行修改的,如不在定义时初始化,系统随便提供的一个指针地址对于程序员来说没有占有感,就像用的个二手指针一样。

譬如:

int *const p; // 错误,系统报错。

int const *p; // 编译通过。

指针为什么不能指向常量?

常量指针意味着指针本身就是常量,和其他const常量一样,需要初始化。

版权声明