嵌入式c语言优化技巧

嵌入式C语言优化技巧

嵌入式系统是指完成一种或几种特定功能的计算机系统,具有自动化程度高,响应速度快等优点,目前已广泛应用于消费电子,工业控制等领域。嵌入式系统受其使用的硬件以及运行环境的限制,非常注重代码的时间和空间效率,因此选择一种合适的开发语言十分重要。下面是相关的知识,欢迎阅读。

目前,在嵌入式系统开发中可使用的语言很多,其中 C语言应用得最广泛。虽然用 C 语言编程具有许多优点,但基于嵌入式系统的C语言和标准 C语言又有很大区别。接下来结合嵌入式系统的特点和高手们的一些积累,给大家整理出在程序设计中代码优化的一些小技巧。

1、嵌入式C语言的特点

作为一种结构化程序设计语言,C 语言兼顾多种高级语言的特点,具有很强的功能性和可移植性。但在嵌入式系统开发中,出于对低价产品的需求,系统的计算能力和存储容量都非常有限,因此如何利用好这些资源就显得十分重要。开发人员应注意嵌入式 C语言和标准 C 语言的区别,减少生成代码长度,提高程序执行效率,在程序设计中对代码进行优化。

2、C代码在程序中的优化

现在的 C 编译器会自动对代码进行优化,但这些优化是对执行速度和代码长度的平衡。如果要获得更小且执行效率更高的代码,需要程序员手工对代码进行优化。

3、变量类型的定义

不同的数据类型所生成的机器代码长度相差很多,变量类型选取的范围越小运行速度越快,占用的内存越少。能够使用字符型(char)定义的变量,就不要使用整型(int)变量来定义;能够使用整型变量定义的变量就不要用长整型(long int),能不使用浮点型(float)变量就不要使用浮点型变量。相同类型的数据类型,有无符号对机器代码长度也有影响。因此我们应按照实际需要合理的选用数据类型。当然,在定义变量后不要超过变量的作用范围,如果超过变量的范围赋值,C编译器并不报错,但程序运行结果却错了,而且这样的错误很难发现。

4、算法优化

算法优化指对程序时空复杂度的优化:在 PC 机上进行程序设计时一般不必过多关注程序代码的长短,只需考虑功能的实现,但嵌入式系统就必须考虑系统的硬件资源,在程序设计时,应尽量采用生成代码短的算法,在不影响程序功能实现的情况下优化算法。

5、适当的使用宏

在C程序中使用宏代码可以提高程序的执行效率。宏代码本身不是函数,但使用起来像函数。函数调用要使用系统的栈来保存数据,同时 CPU 在函数调用时需要保存和恢复当前的现场,进行进栈和出栈操作,所以函数调用也需要 CPU时间。而宏定义就没有这个问题:宏定义仅仅作为预先写好的代码嵌入到当前程序中,不产生函数调用,所占用的仅仅是一些空间,省去了参数压栈,生成汇编语言的 call 调用,返回参数,执行 return等过程,从而提高了程序的执行速度。虽然宏破坏了程序的可读性,使排错更加麻烦,但对于嵌入式系统,为了达到要求的性能,嵌入代码常常是必须的做法。

此外,我们还要避免不必要的函数调用,请看下面的代码:

[plain] view plain copy print?

void str_print( char *str )

{

int i;

for ( i = 0; i < strlen ( str ); i++ )

{

printf("%c",str[ i ] );

}

}

void str_print1 ( char *str )

{

int len;

len = strlen ( str );

for ( i = 0; i < len; i++ )

{

printf("%c",str[ i ] );

}

}

请注意,这两个函数的功能相似。然而,第一个函数调用strlen函数多次,而第二个函数只调用函数strlen一次。因此第二个函数性能明显比第一个好。

6、内嵌汇编

程序中对时间要求苛刻的部分可以用内嵌汇编来重写,以带来速度上的显着提高。但是,开发和测试汇编代码是一件辛苦的工作,它将花费更长的时间,因而要慎重选择要用汇编的部分。在程序中,存在一个80-20原则,即20%的程序消耗了80%的运行时间,因而我们要改进效率,最主要是考虑改进那20%的代码。

7、提高循环语言的效率

在 C 语言中循环语句使用频繁,提高循环体效率的基本办法就是降低循环体的复杂性:

(1) 在多重循环中,应将最长的循环放在最内层,最短的循环放在最外层。这样可以减少 CPU跨切循环的次数。如例 1-1 的效率比 1-2 的效率要低:

[plain] view plain copy print?

for (j = 0; j < 30; j++)

{

for (i = 0; i < 10; i++)

{……}

} // 例子 1-1

for (i = 0; i < 10; i++)

{

for (j = 0; j < 30; j++)

{……}

} // 例子 2-2 程序部简洁但效率高

8、提高 switch 语句的效率

switch 语句是 C 语言中常用的选择语句, 在编译时会产生if- else- if 嵌套代码,并按照顺序进行比较,发现匹配时,就跳转到满足条件的语句执行。

当 switch 语句中的 case 标号很多时,为了减少比较的次数,可以把发生频率相对高的条件放到第一位或者把整个 switch 语句转化嵌套 switch 语句。把发生频率高的 case 标号放在最外层的 switch 语句中,发生相对频率相对低的 case 标号放在另外的 switch 语句中。如例 3 中,把发生率高的case 标号放在外层的 switch 语句中,把发生频率低的放在缺省的(default)内层 switch 语句中。

[plain] view plain copy print?

switch (表达式)

{

case 值1:

语句1: break;

case 值2:

语句2:break;

……

/*把发生频率低的放在内层的switch语句中*/

default:

switch (表达式)

{

case 值n:

语句n: break;

case 值m:

语句m: break;

……

}

}

例子3 使用嵌套switch语句提高程序执行效率。

9、避免使用标准库

使用 C语言标准库可以加快开发进度,但由于标准库需要设法处理用户所有可能遇到的情况,所以很多标准库代码很大。比如标准库中的 sprintf函数非常大。这个庞大的代码中有很大一部分用于处理浮点数,如果程序中不需要格式化浮点数值( 如%f),程序设计人员就可以根据实际情况用少量的代码实现这个功能。

10、采用数学方法优化程序

数学是计算机之母,没有数学的依据和基础,就没有计算机的发展,所以在编写程序的时候,采用一些数学方法会对程序的执行效率有数量级的提高。有时候这个问题常常被大家忽略, 对于没有经验的程序员来说更是如此。例如:求 1~100 的和:

sum = 100*(100+1)/2;

数学公式: (a1 + an)*n/2

使用C语言的位操作可以减少除法和取模的运算。在计算机程序中数据的位是可以操作的最小数据单位,理论上可以用“位运算”来完成所有的运算和操作。因而,灵活的位操作可以有效地提高程序运行的效率。比如用用位操作区代替除法:比如:128 / 8 ->> 128 >> 3;

优化算法和数据结构对提高代码的'效率有很大的帮助。当然有时候时间效率和空间效率是对立的,此时应分析哪个更重要, 做出适当的折中。另外,在进行优化的时候不要片面的追求紧凑的代码,因为紧凑的代码并不能产生高效率的机器码。

11、存储器分配

由于成本限制,嵌入式系统存储器容量有限。程序中所有的变量,包含的库函数以及堆栈等都使用有限的内存:全局变量在整个程序范围内都有效。程序执行完后才会释放;静态变量的作用范围也是整个程序,只有局部变量中的动态变量在函数执行完后会释放。因此, 在程序中应尽量使用局部变量,提高内存使用效率。程序中堆的大小受限于所有全局数据和栈空间都分配后的剩余量,如果堆太小,程序不能够在需要的时候分配内存。因此在使用 malloc 函数申请内存之后一定要用 free 函数进行释放, 防止内存泄露。

12、选择好的无限循环

在编程中,我们常常需要用到无限循环,常用的两种方法是while (1) 和 for (;;)。这两种方法效果完全一样,但那一种更好呢?然我们看看它们编译后的代码:

编译前:

while (1);

编译后:

mov eax,1

test eax,eax

je foo+23h

jmp foo+18h

编译前:

for (;;);

编译后:

jmp foo+23h

显然,for (;;)指令少,不占用寄存器,而且没有判断,跳转,比while (1)好。

13、使用Memoization,以避免递归重复计算

考虑Fibonacci(斐波那契)问题,Fibonacci问题是可以通过简单的递归方法来解决:

[plain] view plain copy print?

1. int fib ( n )

2. {

3. if ( n == 0 || n == 1 )

4. {

5. return 1;

6. }

7. else

8. {

9. return fib( n - 2 ) + fib ( n - 1 );

10. }

11. }

注:在这里,我们考虑Fibonacci 系列从1开始,因此,该系列看起来:1,1,2,3,5,8,…

注意:从递归树,我们计算fib(3)函数2次,fib(2)函数3次。这是相同函数的重复计算。如果n非常大,fib函数的效率会比较低。Memoization是一个简单的技术,可以被用在递归,加强计算速度。fibonacci 函数Memoization的代码如下:

[plain] view plain copy print?

1. int calc_fib ( int n )

2. {

3. int val[ n ] , i;

4. for ( i = 0; i <=n; i++ )

5. {

6. val[ i ] = -1; // Value of the first n + 1 terms of the fibonacci terms set to -1

7. }

8. val[ 0 ] = 1; // Value of fib ( 0 ) is set to 1

9. val[ 1 ] = 1; // Value of fib ( 1 ) is set to 1

10. return fib( n , val );

11. }

12.

13. int fib( int n , int* value )

14. {

15. if ( value[ n ] != -1 )

16. {

17. return value[ n ]; // Using memoization

18. }

19. else

20. {

21. value[ n ] = fib( n - 2 , value ) + fib ( n - 1 , value ); // Computing the fibonacci term

22. }

23. return value[ n ]; // Returning the value

24. }

除了编程上的技巧外,为提高系统的运行效率,我们通常也需要最大可能地利用各种硬件设备自身的特点来减小其运转开销,例如减小中断次数,利用DMA传输方式等。

嵌入式c语言优化技巧

转载请注明出处记得学习 » 嵌入式c语言优化技巧

学习

关于孟晚舟回国的作文

阅读(69)

本文为您介绍关于孟晚舟回国的作文800字,内容包括关于孟晚舟回国的作文800字高二,关于孟晚舟回国的作文,孟晚舟事件有感作文800字。关于孟晚舟回国的作文800字在生活、工作和学习中,大家最不陌生的就是作文了吧,作文要求篇章结构完整,一定

学习

杀戮的近义词是什么

阅读(97)

本文为您介绍杀戮的近义词是什么,内容包括杀戮的近义词是什么呢,杀戮的近义词是,杀戮为乐的近义词是什么。杀戮的近义词是什么近义词,是指词汇意义相同或相近的词语,如“美好”和“美妙”、“懒惰”和“怠惰”、“枯萎”和“干枯”、“宽

学习

什么是嵌入式操作系统

阅读(87)

本文为您介绍什么是嵌入式操作系统,内容包括什么是嵌入式操作系统有哪些特点,什么是嵌入式操作系统的移植,什么是通用桌面操作系统。什么是嵌入式操作系统常见的嵌入式系统有:Linux、uClinux、WinCE、PalmOS、Symbian、eCos、uCOS-II

学习

赞美韩信的作文

阅读(96)

本文为您介绍赞美韩信的作文550字,内容包括韩信600-800字作文,英雄韩信作文1000字,韩信作文素材字。兵仙韩信作文450字(精选6篇)在学习、工作、生活中,许多人都写过作文吧,写作文可以锻炼我们的独处习惯,让自己的心静下来,思考自己未来的方向

学习

玩具士兵作文

阅读(81)

本文为您介绍玩具士兵作文,内容包括玩具兵大战2完整版,玩具兵大战游戏解说,玩具兵大战乐高士兵。玩具兵大战作文700字在现实生活或工作学习中,许多人都有过写作文的经历,对作文都不陌生吧,借助作文人们可以反映客观事物、表达思想感情、传

学习

嵌入式系统基础知识

阅读(73)

本文为您介绍嵌入式系统基础知识,内容包括嵌入式系统基础知识点,嵌入式基础知识大全,嵌入式系统入门基础知识。嵌入式系统基础知识嵌入式系统是一种专用的计算机系统,作为装置或设备的一部分。通常,嵌入式系统是一个控制程序存储在ROM中的

学习

少年边防兵读后感范文

阅读(78)

本文为您介绍少年边防兵读后感400字范文,内容包括我是一个少年边防兵读后感400字,我是一个少年边防兵读后感范文,少年边防兵读后感350字范文。我是一个兵少年边防兵读后感350字读完某一作品后,大家心中一定是萌生了不少心得,这时候,最关键

学习

孟佩杰读后感

阅读(94)

本文为您介绍孟佩杰读后感,内容包括孟佩杰的事迹读后感,孟佩杰事件读后感100字,孟佩杰事迹读后感字。孟佩杰读后感400字认真品味一部名著后,相信大家都积累了属于自己的读书感悟,需要回过头来写一写读后感了。那么我们如何去写读后感呢?下

学习

嵌入式系统体系结构

阅读(65)

本文为您介绍嵌入式系统体系结构,内容包括嵌入式系统体系结构是什么,嵌入式系统体系结构与设计,嵌入式系统两种体系结构。嵌入式系统体系结构所有带有数字接口的设备,如手表、微波炉、录像机、汽车等,都使用嵌入式系统,有些嵌入式系统还包

学习

范滂字孟博文言文翻译

阅读(72)

本文为您介绍范滂字孟博文言文翻译,内容包括范滂字孟博出自哪篇文言文,范滂孟博文言文朗读,范滂传文言文阅读答案。关于范滂字孟博的阅读答案及翻译在学习和工作的日常里,我们很多时候需要适量地做些阅读题,就有可能接触到阅读答案,阅读答

学习

秋凉作文

阅读(85)

本文为您介绍秋凉作文100篇,内容包括秋天即景500字,秋天清冷作文,秋天寂寞悲凉的作文。秋寂500字作文(通用26篇)在日常学习、工作抑或是生活中,大家都写过作文吧,作文是经过人的思想考虑和语言组织,通过文字来表达一个主题意义的记叙方法。还

学习

关于十二生肖鸡的谚语和歇后语

阅读(89)

本文为您介绍关于十二生肖鸡的谚语和歇后语,内容包括十二生肖鸡的俗语,十二生肖雄鸡的赞美,鸡生肖吉祥语。十二生肖谚语之鸡的谚语导语:鸡是十二生肖之一,鸡一般象征聪明灵敏,下面是语文迷收集整理的关于鸡的谚语,欢迎大家阅读参考!十二生肖

学习

关于小鸡童年趣事作文

阅读(72)

本文为您介绍关于小鸡童年趣事100字作文,内容包括童年趣事给冰棍洗澡作文,童年趣事给乌龟洗澡作文,童年趣事给小鸡洗澡作文。童年趣事之给鸡洗澡作文(精选14篇)在平时的学习、工作或生活中,大家都写过作文吧,作文是由文字组成,经过人的思想考

学习

十二生肖之鸡的歇后语集锦

阅读(70)

本文为您介绍十二生肖之鸡的歇后语集锦,内容包括黄鼠狼给鸡拜年的歇后语是什么,十二生肖鸡的歇后语大全,关于十二生肖鸡的谚语和歇后语。十二生肖之鸡的歇后语集锦歇后语是汉语的一种特殊语言形式。是群众在生活实践中所创造的一种特殊

学习

什么是嵌入式操作系统

阅读(87)

本文为您介绍什么是嵌入式操作系统,内容包括什么是嵌入式操作系统有哪些特点,什么是嵌入式操作系统的移植,什么是通用桌面操作系统。什么是嵌入式操作系统常见的嵌入式系统有:Linux、uClinux、WinCE、PalmOS、Symbian、eCos、uCOS-II

学习

嵌入式系统基础知识

阅读(73)

本文为您介绍嵌入式系统基础知识,内容包括嵌入式系统基础知识点,嵌入式基础知识大全,嵌入式系统入门基础知识。嵌入式系统基础知识嵌入式系统是一种专用的计算机系统,作为装置或设备的一部分。通常,嵌入式系统是一个控制程序存储在ROM中的

学习

什么是嵌入式衣柜

阅读(65)

本文为您介绍什么是嵌入式衣柜,内容包括嵌入式隐形衣柜最新款式,砌墙做嵌入式衣柜,嵌入式衣柜的做法。什么是嵌入式衣柜有许多人或许还不了解嵌入式衣柜,但却发现有很多家庭在装修时都会做嵌入式衣柜,那到底什么是嵌入式衣柜呢?下面就由为

学习

嵌入式实习报告

阅读(61)

本文为您介绍嵌入式实习报告,内容包括嵌入式实习报告总结,嵌入式实习报告1万字,嵌入式实习报告怎么写。嵌入式实习报告辛苦的实习生活在不经意间已告一段落了,这段时间里,一定有很多值得分享的经验吧,不能光会埋头苦干哦,写一份实习报告吧。

学习

嵌入式烤箱尺寸有多少

阅读(73)

本文为您介绍嵌入式烤箱尺寸有多少,内容包括嵌入式烤箱尺寸,嵌入式烤箱尺寸一般是多少,一般家用烤箱多少升就够了。嵌入式烤箱尺寸有多少导语:嵌入式烤箱的尺寸是多少?人们越来越注重居家品质生活,嵌入式烤箱的需求量无疑是与日俱增,嵌入式

学习

嵌入式操作系统的功能

阅读(82)

本文为您介绍嵌入式操作系统的功能,内容包括嵌入式操作系统的功能有哪些,嵌入式操作系统必须具备的功能,嵌入式操作系统的基本功能是什么。嵌入式操作系统的功能根据英国电气工程师协会的定义,嵌入式系统为控制、监视或辅助设备、机器或

学习

安卓手机如何优化设置

阅读(87)

本文为您介绍安卓手机如何优化设置,内容包括安卓手机如何优化设置才能流畅,安卓手机哪个系统优化最好,安卓手机设置提高流畅。安卓手机如何优化设置一直以来安卓手机给人的感觉都是各种卡顿,尤其是开的程序比较多以后,和iPhone比较起来流

学习

语言类论文模板范文

阅读(95)

本文为您介绍语言类论文模板范文,内容包括语言学论文的撰写要求,语言学论文怎么写,大学语言学论文答辩常见问题。语言学论文的撰写要求(精选10篇)在学习和工作中,大家最不陌生的就是论文了吧,论文是讨论某种问题或研究某种问题的文章。相信