有时他们期望表述这种一类函数,它的值无法被发生改变,在整座返回值中都维持一般来说。比如,用两个函数来则表示年级的最小数目,或是则表示头文件的大小不一。为的是满足用户而此明确要求,能采用constURL对函数予以限量发行:
1.const int MaxNum = 100; //年级的最小数目
这种 MaxNum 的值就无法被修正了,任何人对 MaxNum 函数的犯罪行为都将引起严重错误:
2.MaxNum = 90; //严重错误,企图向 const 函数载入统计数据
他们时常将 const 函数称作自函数(Constant)。建立自函数的文件格式一般来说为:
const type name = value;
const 和 type 都是用以润色函数的,它的边线能交换,也是将 type 放到 const 前面:
type const name = value;
但他们一般来说选用第二种方式,不选用第三种方式。除此之外提议将自函数名的第两个字母小写,以告诫开发人员这是个自函数。
虽然自函数除非被建立后其值就无法再发生改变,因此自函数要在表述的与此同时函数(调用),前面的任何人函数犯罪行为都将引起严重错误。不遗余力,调用自函数能采用任一方式的函数,如下表所示右图:
#include <stdio.h>
int getNum(){
return 100;
}
int main(){
int n = 90;
const int MaxNum1 = getNum(); //运转时调用
const int MaxNum2 = n; //运转时调用
const int MaxNum3 = 80; //编译时调用
printf(“%d, %d, %d\n”, MaxNum1, MaxNum2, MaxNum3);
return 0;
}
运转结果:
100, 90, 80
const 和指针
const 也能和指针函数一起采用,这种能限制指针函数本身,也能限制指针指向的统计数据。const 和指针一起采用会有几种不同的顺序,如下表所示右图:
const int *p1;
int const *p2;
int * const p3;
在最后一类情况下,指针是只读的,也是 p3 本身的值无法被修正;在前面两种情况下,指针所指向的统计数据是只读的,也是 p1、p2 本身的值能修正(指向不同的统计数据),但它指向的统计数据无法被修正。
当然,指针本身和它指向的统计数据都有可能是只读的,下面的两种写法能够做到而此点:
const int * const p4;
int const * const p5;
const 和指针结合的写法多少有点让初学者摸不着头脑,大家能这种来记忆:const 离函数名近是用以润色指针函数的,离函数名远是用以润色指针指向的统计数据,如果近的和远的都有,那么就与此同时润色指针函数以及它指向的统计数据。
const 和函数形参
在C词汇中,单独表述 const 函数没有明显的优势,完全能采用#define命令代替。const 一般来说用在函数形参中,如果形参是两个指针,为的是防止在函数内部修正指针指向的统计数据,就能用 const 来限制。
在C词汇标准库中,有很多函数的形参都被 const 限制了,下面是部分函数的原型:
size_t strlen ( const char * str );
int strcmp ( const char * str1, const char * str2 );
char * strcat ( char * destination, const char * source );
char * strcpy ( char * destination, const char * source );
int system (const char* command);
int puts ( const char * str );
int printf ( const char * format, … );
他们自己在表述函数时也能采用 const 对形参予以限制,比如查找字符串中某个字符出现的次数:
#include <stdio.h>
size_t strnchr(const char *str, char ch){
int i, n = 0, len = strlen(str);
for(i=0; i
if(str[i] == ch){
n++;
}
}
return n;
}
int main(){
char *str = “http://c.biancheng.net“;
char ch = t;
int n = strnchr(str, ch);
printf(“%d\n”, n);
return 0;
}
运转结果:3
根据 strnchr() 的功能能推断,函数内部要对字符串 str 进行遍历,不应该有修正的动作,用 const 予以限制,不但能防止虽然开发人员误操作引起的字符串修正,还能给用户两个提示,函数不会修正你提供的字符串,请你放心。
const 和非 const 类型转换
当两个指针函数 str1 被 const 限制时,并且类似const char *str1这种方式,说明指针指向的统计数据无法被修正;如果将 str1 函数给除此之外两个未被 const 润色的指针函数 str2,就有可能发生危险。因为通过 str1 无法修正统计数据,而函数后通过 str2 能够修正统计数据了,意义发生了转变,因此编译器不提倡这种犯罪行为,会给出严重错误或警告。
也是说,const char *和char *是不同的类型,无法将const char *类型的统计数据函数给char *类型的函数。但反过来是能的,编译器允许将char *类型的统计数据函数给const char *类型的函数。
这种限制很容易理解,char *指向的统计数据有读取和载入权限,而const char *指向的统计数据只有读取权限,降低统计数据的权限不会带来任何人问题,但提升统计数据的权限就有可能发生危险。
C词汇标准库中很多函数的参数都被 const 限制了,但他们在以前的编码过程中并没有注意这个问题,时常将非 const 类型的统计数据传递给 const 类型的形参,这种做从未引起任何人副作用,原因是上面讲到的,将 const 类型转换为非 const 类型是允许的。
下面是两个将 const 类型函数给非 const 类型的例子:
#include <stdio.h>
void func(char *str){ }
int main(){
const char *str1 = “http://c.biancheng.net“;
char *str2 = str1;
func(str1);
return 0;
}
第7、8行代码分别通过函数、传参(传参的本质也是函数)将 const 类型的统计数据交给了非 const 类型的函数,编译器不会容忍这种犯罪行为,会给出警告,甚至直接报错。
“我是一名从事了10年开发的老开发人员,最近我花了一些时间整理关于C词汇、C++,自己有做的材料的整合,两个完整的学习C词汇、C++的路线,学习材料和工具。全球最小的C/C++爱好者就在我这里。这里是编程爱好者的聚集地,欢迎初学和进阶中的小伙伴。期望你也能凭自己的努力,成为下两个优秀的开发人员。工作需要、感兴趣、为的是入行、转行需要学习C/C++的伙伴能跟我一起学习!”
!