嵌入式软件开发C语言中 const 关键词的妙用之处

2023-05-29 0 644

#裂稃学识#

有时他们期望表述这种一类函数,它的值无法被发生改变,在整座返回值中都维持一般来说。比如,用两个函数来则表示年级的最小数目,或是则表示头文件的大小不一。为的是满足用户而此明确要求,能采用constURL对函数予以限量发行:

const int MaxNum = 100; //年级的最小数目

这种 MaxNum 的值就无法被修正了,任何人对 MaxNum 函数的犯罪行为都将引起严重错误:

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 * constp5;

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<len; i++){ if(str[i] == ch){ n++; } }return n; } int main(){ char *str = “http://c.biancheng.net”; char ch = t; intn = 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 = “c.biancheng.net”; char *str2 = str1; func(str1); return 0; }

第7、8行代码分别通过函数、传参(传参的本质也是函数)将 const 类型的统计数据交给了非 const 类型的函数,编译器不会容忍这种犯罪行为,会给出警告,甚至直接报错。

相关文章

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

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