Keil MDK 和 IAR 兩款ARM開發工具區別比較


首先要說明,沒有那款開發工具是萬能的,也沒有那款工具在所有方面都具有絕對優勢。對於Keil MDK-ARM和IAR兩款工具擇,可以根據自己的習慣來選擇,而不應該在使用其中的一款時貶低另外一款,或者總是贊美自己的選擇。

 

好了,下面開始講Keil MDK-ARM和IAR的區別。

 

一、概述

 


Keil MDK-ARM(舊稱RealView MDK)開發工具源自德國Keil公司,被全球上百萬的嵌入式開發工程師驗證和使用,是ARM公司目前最新推出的針對各種嵌入式處理器的軟件開發工具。

KEIL MDK集成了業內最領先的技術,包括uVision3、uVision4、uVision5集成開發環境與 ARM編譯器。支持ARM7、ARM9、Cortex-M0、Cortex-M0+、Cortex-M3、Cortex-M4、Cortex-R4內核核處理器。

Keil MDK可以自動配置啟動代碼,集成Flash燒寫模塊,強大的Simulation設備模擬,性能分析等功能,與ARM之前的工具包ADS等相比,ARM編譯器的最新版本可將性能改善超過20%以上。
  
IAR Embedded Workbench是一套用於編譯和調試嵌入式系統應用程序的開發工具,支持匯編、C和C++語言。它提供完整的集成開發環境,包括工程管理器、編輯器、編譯鏈接工具和C-SPY調試器。IAR Systems以其高度優化的編譯器而聞名。每個C/C++編譯器不僅包含一般全局性的優化,也包含針對特定芯片的低級優化,以充分利用您所選芯片的所有特性,確保較小的代碼尺寸。IAR Embedded Workbench能夠支持由不同的芯片制造商生產,且種類繁多的8位、16位或32位芯片。

 

二、區別


 1、MDK不支持層疊文件夾,在文件夾的下一級中必須為文件;IAR支持層疊,可以比較方便管理代碼,理清層次。

            

 

2、MDK連接library,直接添加到文件夾即可;IAR則需要從工程中選項中設置。這應該不算什么問題,畢竟大多數IDE都是這么做的,但最讓人很郁悶的是,IAR不能采用相對路徑。比如../MUF/MUF.LIB在編譯時,就會連接到別的目錄,只能采用d:/MUF/MUF.lib絕對路徑的形式。

 

3、 MDK支持dynamic_cast<>運算符,而IAR文檔中明確表示不支持。如果在IAR中強行使用該運算符,則編譯會報錯:

Error[Pe020]: identifier "dynamic_cast" is undefined

 

4、MDK默認只創建工程,工作區是不會直接創建。如果想多個工程聚合,則首先需要創建一個multi的工作區,然后再添加相應的工程。  IAR,默認是創建工程和工作區,如果想多個工程並存,直接添加即可。  相比之下,MDK創建工程的文件比較少,而IARM創建工程生成的文件比較多。

 

5、MDK編譯時,只有level的選擇;IAM有debug和Release的快速選擇

 

6、默認狀態,MDK的工具欄功能比較多,有點繁雜;IAM的比較簡潔,但相對,也比較單薄。

 

7、MDK的C++有std::這個命名空間;IAR下面的所有容器和算法,都不采用std命名空間

 

8、MDK的程序文件,最后必須要有一個新的空行,否則會有編譯警告:

warning:  #1-D: last line of file ends without a newline


一般來說,如果主要是采用C,並且也不會有太多的library需要連接,MDK和IAR都能勝任。不過這種情形就比較推薦IAR,因為其非常簡潔,上手也快,代碼層次也能清晰明了。
  
如果主要是采用C++,並且用到很多特性,或是需要有多個工程進行協作,那么注定只能選擇MDK,只不過這樣就一定要每個文件最后加上新的空行了。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM