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常量一样,需要初始化。