新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > 基于ARM的高效C語言編程

        基于ARM的高效C語言編程

        作者: 時間:2010-09-29 來源:網絡 收藏

        引言

        本文引用地址:http://www.104case.com/article/151466.htm

          處理器以其高性能、低功耗、低成本等優勢被廣泛應用于各種成功的32位嵌入式系統中。提高執行速度和減小代碼尺寸是嵌入式軟件設計的關鍵需求。盡管大多數的編譯器和調試器都帶有性能優化工具,但是為了保證其正確性,編譯器必須是穩妥和安全的,而且它還受到處理器自身結構的限制。因此,編程人員必須在理解編譯器工作特點的基礎上來實現代碼優化。代碼的優化方法較多,本文針對函數優化方法進行闡述。

          1 函數局部變量的數據類型

          局部變量包括函數內局部變量、函數參數、函數返回值。由于數據操作都是32位,即使數據本身只需要8位或16位,對于這三類局部變量也應盡可能使用32位的數據類型int或lONg,以提高代碼執行效率。下面以簡單求和函數為例進行分析。

          函數add1計算包含10個字的數組array的累加和,add2與add1功能相同,只是將函數add1的參數array類型改為16位的short,函數內局部變量i類型改為8位的char,sum改為16位的short。add1、add2的C源代碼如下:

          int add1(int *array){

          unsigned int i;

          int sum=0;

          for(i=0;i10;i++)

          sum=sum+array[i];

          return sum;

          }

          short add2(short *array){

          char i;

          short sum=0;

          for(i=0;i10;i++)

          sum= sum+array[i];

          return sum;

          }

          add1經編譯產生的匯編代碼:

          add1

          mov r2,r0

          mov r0,#0

          mov r1,#0

          add1_loop

          ldr r3,[r2,r1,lsl #2]

          add r1,r1,#1

          cmp r1,#0x0a

          add r0,r3,r0

          bcc add1_loop

          mov pc,r14

          add2經編譯產生的匯編代碼:

          add2

          mov r2,r0

          mov r0,#0

          mov r1,#0

          add2_loop


        上一頁 1 2 3 下一頁

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 金华市| 阿克苏市| 万年县| 高雄县| 工布江达县| 汝阳县| 日土县| 黑龙江省| 镇远县| 祁门县| 罗江县| 白水县| 滦平县| 讷河市| 黄浦区| 苏尼特左旗| 长寿区| 安仁县| 涟源市| 景德镇市| 苍南县| 宁武县| 云安县| 建德市| 唐海县| 武宣县| 庆云县| 吴旗县| 浦城县| 土默特左旗| 太原市| 龙口市| 陕西省| 呼玛县| 西畴县| 隆林| 阿拉善右旗| 公安县| 平邑县| 辰溪县| 永顺县|