欢迎来到天天文库
浏览记录
ID:51686966
大小:41.95 KB
页数:6页
时间:2020-03-15
《C语言中const的用法.doc》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、C语言中const的用法 const是一个C语言的关键字,它限定一个变量不允许被改变。使用const在一定程度上可以提高程序的安全性和可靠性,另外,在观看别人代码的时候,清晰理解const所起的作用,对理解对方的程序也有一些帮助。 我们来分情况看语法上它该如何被使用。 1、函数体内修饰局部变量。 例: voidfunc() { constinta=0; } 首先,我们先把const这个单词忽略不看,那么a是一个int类型的局部自动变量,我们给它赋予初始值0。然后再看const.
2、const作为一个类型限定词,和int有相同的地位。 constinta; intconsta; 是等价的。于是此处我们一定要清晰的明白,const修饰的对象是谁,是a,和int没有关系。const要求他所修饰的对象为常量,不可被改变,不可被赋值,不可作为左值(l-value)。 这样的写法也是错误的。 constinta; a=0; 这是一个很常见的使用方式: constdoublepi=3.14; 在程序的后面如果企图对pi再次赋值或者修改就会出错。 然后看一个稍微复杂的例
3、子。 constint*p; 还是先去掉const修饰符号。 注意,下面两个是等价的。 int*p; int*p; 其实我们想要说的是,*p是int类型。那么显然,p就是指向int的指针。 同理 constint*p; 其实等价于 constint(*p); intconst(*p); 即,*p是常量。也就是说,p指向的数据是常量。 于是 p+=8;//合法 *p=3;//非法,p指向的数据是常量。 那么如何声明一个自身是常量指针呢?方法是让const尽可
4、能的靠近p; int*constp; const右面只有p,显然,它修饰的是p,说明p不可被更改。然后把const去掉,可以看出p是一个指向int形式变量的指针。 于是 p+=8;//非法 *p=3;//合法 再看一个更复杂的例子,它是上面二者的综合 constint*constp; 说明p自己是常量,且p指向的变量也是常量。 于是 p+=8;//非法 *p=3;//非法 const还有一个作用就是用于修饰常量静态字符串。 例如: constchar*name="
5、David"; 如果没有const,我们可能会在后面有意无意的写name[4]='x'这样的语句,这样会导致对只读内存区域的赋值,然后程序会立刻异常终止。有了const,这个错误就能在程序被编译的时候就立即检查出来,这就是const的好处。让逻辑错误在编译期被发现。 const还可以用来修饰数组 constchars[]="David"; 与上面有类似的作用。 2、在函数声明时修饰参数 来看实际中的一个例子。 NAME memmove--copybytestring LIBRARY
6、 StandardCLibrary(libc,-lc) SYNOPSIS #include void* memmove(void*dst,constvoid*src,size_tlen); 这是标准库中的一个函数,用于按字节方式复制字符串(内存)。它的第一个参数,是将字符串复制到哪里去(dest),是目的地,这段内存区域必须是可写。它的第二个参数,是要将什么样的字符串复制出去,我们对这段内存区域只做读取,不写。于是,我们站在这个函数自己的角度来看,src这个指针,它所指向的内存
7、内所存储的数据在整个函数执行的过程中是不变。于是src所指向的内容是常量。于是就需要用const修饰。例如,我们这里这样使用它。 constchar*s="hello"; charbuf[100]; memmove(buf,s,6);//这里其实应该用strcpy或memcpy更好 如果我们反过来写, memmove(s,buf,6); 那么编译器一定会报错。事实是我们经常会把各种函数的参数顺序写反。事实是编译器在此时帮了我们大忙。如果编译器静悄悄的不报错,(在函数声明处去掉const即可),那
8、么这个程序在运行的时候一定会崩溃。 这里还要说明的一点是在函数参数声明中const一般用来声明指针而不是变量本身。 例如,上面的size_tlen,在函数实现的时候可以完全不用更改len的值,那么是否应该把len也声明为常量呢?可以,可以这么做。我们来分析这么做有什么优劣。 如果加了const,那么对于这个函数的实现者
此文档下载收益归作者所有