C语言const的用法详解,C语言常量定义详解!

2023-09-06 0 769

有时他们期望表述这种一类函数,它的值无法被发生改变,在整座返回值中都维持一般来说。比如,用两个函数来则表示年级的最小数目,或是则表示头文件的大小不一。为的是满足用户而此明确要求,能采用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++的伙伴能跟我一起学习!”

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务