現(xiàn)在是一個物聯(lián)網(wǎng)的世界,很多人選擇了做物聯(lián)網(wǎng)項目。 對于物聯(lián)網(wǎng)項目而言,選擇編程語言的重要意義絕不在制定硬件平臺決策之下。在今天的文章中,我們將共同審視11款編程語言,并認真考量哪一種最適合自己的下一個編程項目。 物聯(lián)網(wǎng)開發(fā)項目目前正在全球范圍的諸多企業(yè)當中如火如荼地展開。新型硬件平臺的出現(xiàn)讓工程師們能夠以前所未有的便捷方式在物聯(lián)網(wǎng)應(yīng)用當中構(gòu)建嵌入式系統(tǒng)。一旦選定了合適的硬件平臺,接下來要做的就是為其開發(fā)應(yīng)用軟件——先別高興得太早,到了這一步擺在我們面前的選項會更多、也更具挑戰(zhàn)。 就在不久之前,我們對于編程語言的選擇還受到硬件平臺方案的嚴格約束。不過時至今日,多數(shù)現(xiàn)代平臺已經(jīng)基于開源標準并能夠支持多種編程語言類型,這樣出色的靈活性自然帶來了更多潛在選項。而這也正是我們今天所要解決的問題。 那么我們應(yīng)該如何為特定物聯(lián)網(wǎng)項目選擇編程語言呢?在某些情況下,我們的潛在選項仍然會受到當前硬件平臺的限定。不過在其它條件下,大家完全可以立足于特定因素選擇語言類型,例如企業(yè)開發(fā)團隊對該語言的熟悉程度、其能夠在業(yè)務(wù)環(huán)境中整體物聯(lián)網(wǎng)系統(tǒng)的其它組件所使用,或者其代碼成果是否體積更小、執(zhí)行效率更高或者編寫速度更快等等。 我們首先從眾多選項中挑選出了11款最為出色的語言,它們都能夠很好地完成嵌入式系統(tǒng)的編程任務(wù)。它們涵蓋范圍很廣,從用途廣泛的C++以及Java到專門面向嵌入式用例的Go以及Parasail皆在其中。每一款語言都有著自己的優(yōu)勢與局限。在閱讀了今天的文章之后,也希望大家能夠在評論當中表達您的觀點與較為傾向的語言選項,幫助我們共同了解如何更好地構(gòu)建起自己的嵌入式與物聯(lián)網(wǎng)開發(fā)項目。 C語言 作為一款最初用于進行電話交換機編程的語言,C確實是我們在考慮嵌入式系統(tǒng)開發(fā)時應(yīng)當首先審視的合理選項。C語言屬于軟件開發(fā)世界中的一種通用語,其適用于幾乎每一款現(xiàn)有高級嵌入式系統(tǒng)平臺。某些平臺雖然無法直接支持C語言,但不可否認的是其仍然以基礎(chǔ)形式存在,支撐著SDK中的那些專用語言。 好消息是專業(yè)程序員們必然對C語言擁有較為深入的了解——如果做不到這一點,那么企業(yè)應(yīng)該撥出專項資金幫助大家完成進修,這對于程序員自身的職業(yè)發(fā)展以及企業(yè)運營前景來說都將物有所值。從當下的角度審視,C語言身上確實存在著諸多過于陳舊的因素:它屬于過程語言而非面向?qū)ο笳Z言;它并不具備內(nèi)置的圖形用戶界面;而且采用編譯而非解釋機制。不過這一切負面因素反而在物聯(lián)網(wǎng)開發(fā)項目當中讓其成為最強而有力的語言候選人之一。 C++ 自從上世紀八十年代初整個編程世界的發(fā)展車輪開始朝著面向?qū)ο笳Z言滾動之時,F(xiàn)ortran、Cobol以及C這樣的過程語言就似乎注定了被人遺忘的命運。目前Fortran與Cobol已經(jīng)徹底淪為利基型語言(雖然Cobol的利基范圍比較可觀,但其定位局限仍然非常明顯),而C語言則憑借著Bjarne Stroustrup的工作成果而繼續(xù)停留在公眾視野當中——其貢獻是為C語言開發(fā)出了一款面向?qū)ο蟮念A(yù)處理程序,也就是我們所熟知的C++。 C++保留了C語言的特性,但同時加入了數(shù)據(jù)抽象、類以及對象等機制。這一切讓C++因為我們在Linux系統(tǒng)環(huán)境中編寫嵌入式及物聯(lián)網(wǎng)代碼時的熱門選項。這款編程語言自誕生至今已經(jīng)跨越了三十多年的時光,但其在如今的嵌入式及物聯(lián)網(wǎng)開發(fā)領(lǐng)域仍然極具生命力。 Java C與C++從起步階段的設(shè)計初衷就一直在于對其運行所在的硬件平臺進行直接控制。這種特性在需要對硬件進行細化程度極高的監(jiān)測及控制時確實優(yōu)勢明顯,但這同時也意味著我們所編寫的代碼需要從非常具體的角度考量硬件狀況。而用編程圈里的行話來說,就是代碼不太適合進行移植。 Java的設(shè)計思路則被打造成一款面向?qū)ο笳Z言,因此具備非常出色的可移植性:編譯器當中幾乎不存在任何硬件依賴性。而要對特定硬件進行特殊而準確的控制,Java需要借助硬件所支持的庫并從中調(diào)用通用代碼。 這一切都讓Java擁有極具吸引力的經(jīng)濟性定位:對Java代碼開發(fā)進行一次性投入,企業(yè)將能夠獲得足以運行在多種不同平臺之上的開發(fā)成果。Java同時也是當前人氣最高的主流編程語言之一,其被應(yīng)用于成千上萬計算機科學(xué)與電子工程技術(shù)項目當中。因此我們能夠從人才市場上輕松找到能夠勝任相關(guān)工作的應(yīng)聘者。但從另一方面講,選擇Java的問題在于我們必須確保自己所選定的平臺能夠支持Java(目前只有極少數(shù)強大的平臺會提供Java支持能力),同時又要保證這些硬件能夠支持我們?yōu)榱藢崿F(xiàn)特定控制功能所需要使用的庫。 JavaScript 從表面上看,大家很容易誤以為JavaScript屬于Java語言的某種衍生版本。完全可以理解,不過完全錯誤。這兩種語言確實在某種程度上存在類似或者說交集(例如某些庫可以同時與二者相兼容),但二者的開發(fā)過程完全獨立而且并不共享任何語法或者語義。 顧名思義,JavaScript是一種腳本語言,被廣泛應(yīng)用于構(gòu)建Web前端應(yīng)用。如果大家打算在Raspberry Pi硬件平臺上使用Apache服務(wù)器,旨在從由Arduino傳感器構(gòu)建的網(wǎng)絡(luò)當中提取數(shù)據(jù),那么JavaScript絕對是個很好的起步選項。 自從被網(wǎng)景公司開發(fā)出來之時,JavaScript就一直在快速發(fā)展演進并已經(jīng)成為一款功能齊備的語言。不過大家千萬別把它當成是什么輕量化嵌入式控制器——它所采用的解釋結(jié)構(gòu)意味著我們需要承擔其運行成本。換言之,至少也得是Raspberry Pi這樣的系統(tǒng)才能承擔JavaScript所帶來的性能損失。 Python 這款在假期閑暇時間開發(fā)而成并借用著名喜劇團體命名的編程語言從表面上看似乎不太可能成為嚴肅開發(fā)項目的備選方案。然而事實證明,Python如今已經(jīng)成為Web開發(fā)領(lǐng)域最具活力的語言選項之一,而且其應(yīng)用范圍已經(jīng)擴散到了嵌入式控制以及物聯(lián)網(wǎng)領(lǐng)域。Python在很多方面擁有極為出色的靈活性表現(xiàn)。舉例來說,它作為一種解釋語言能夠被提交至單一運行時編譯器當中,或者通過其中內(nèi)置的預(yù)編譯器實現(xiàn)代碼運行,從而對其緊湊的可執(zhí)行代碼進行分發(fā)。 而最讓編程團隊心動的是,Python語言擁有自己的一大專注重點,即高度強調(diào)代碼內(nèi)容的可讀性。這款語言的設(shè)計規(guī)范提到了代碼可讀性以及緊湊優(yōu)雅語法的重要意義。任何一位曾經(jīng)試圖解讀他人C語言代碼并希望對其進行優(yōu)化的朋友,應(yīng)該都能深刻感受到代碼可讀性在實際工作中的關(guān)鍵作用。 與本篇文章提到的其它語言一樣,Python充當嵌入式語言的前提在于其運行所處的嵌入式平臺需要具備一定的計算能力。如果大家希望開發(fā)的是一款能夠獲取數(shù)據(jù)、將其以某種數(shù)據(jù)庫格式加以整理,而后匯總成表以實現(xiàn)信息控制的應(yīng)用方案,那么Python絕對是位頗具競爭力的候選編程語言選手。 Go 首先必須強調(diào)一點:這里說的是“Go”,而不是“Go!”二者屬于完全不同的兩種語言,而且擁有完全不同的功能定位。Go由谷歌公司負責開發(fā)并廣泛適用于各類處理器及平臺。雖然它只是眾多源自C設(shè)計理念的編程語言當中的一種,但卻在面向特定嵌入式編程類型時擁有大量遠勝C語言的功能特性。 Go語言增加了一種顯式散列表類型,這些類型在從各種傳感器及執(zhí)行器處收集數(shù)據(jù)并向其發(fā)送數(shù)據(jù)方面具備相當突出的實用性。Go語言還深入支持使用傳感器以及設(shè)備網(wǎng)絡(luò)的能力——當然,這同時也增加了潛在風(fēng)險。 Go語言能夠大多種不同通道上支持并行輸入、輸出與處理。如果能夠正確使用,這一能力將使得整套傳感器及執(zhí)行器組合得到良好協(xié)調(diào)。然而這種特性的風(fēng)險在于,各通道之間也許并不能意識到對方的存在。如果編程人員有所疏忽,那么缺乏協(xié)調(diào)的系統(tǒng)就可能帶來不可預(yù)測的行為。從技術(shù)角度講,這顯然不是什么好事。 Rust Rust語言由Mozilla公司開發(fā)而來。與Mozilla旗下的其它軟件類似,Rust屬于開源項目且擁有非常迅猛的演進速度。Rust語言擁有諸多源自Go的特性,不過它也解決了Go當中存在的一大主要問題。 由于Go語言無法自動在不同數(shù)據(jù)結(jié)構(gòu)“通道”之間進行信息共享,因此最終開發(fā)出的程序有可能存在所謂“競態(tài)條件”。直白地講,這是一種無法控制的狀態(tài),處于這一狀態(tài)下的系統(tǒng)會由于不同進程在運行時處于激烈沖突而導(dǎo)致工作無法完成。Rust語言當中包含的函數(shù)能夠消除競態(tài)條件,從而使其更為可靠地構(gòu)建起高度并發(fā)程序。 同樣的,Rust語言對于運行平臺的性能也存在一定要求,不過如果大家的開發(fā)團隊希望開發(fā)一款涉及大量并發(fā)機制的應(yīng)用,那么Rust與Go都是值得認真考量的編程語言選項。 Parasail 如果大家對于自己物聯(lián)網(wǎng)應(yīng)用程序的并行處理能力擁有一定要求,那么Parasail語言也是個值得一試的選項。在之前介紹Go與Rust語言時,我們已經(jīng)提到了編程概念當中的并發(fā)機制。如果大家不清楚并發(fā)與并行的區(qū)別(或者您的開發(fā)團隊無法明確解釋二者的差異),那么請在著手編碼之前認真查尋相關(guān)資料,保證自己的徹底明確之后再做決定。 Parasail是一款編譯型面向?qū)ο笳Z言,其始終處于演進當中因此能夠通過與Java、Python、C#甚至是Ada(真的很難相信會在一種現(xiàn)代語言當中看到Ada的名頭)類似的語法進行編程。千萬別會錯意,如果大家打算構(gòu)建一個物聯(lián)網(wǎng)項目,那么利用Ada進行編程絕對是個不錯的選擇。不過如果大家需要使用具備高度并行性的嵌入式代碼,那么Parasail則是最理想的語言選項。 B# 我們今天提到的很多語言都屬于大型系統(tǒng)語言,因此要讓其在嵌入式平臺上順利運行,我們需要對其進行具體調(diào)整。然而B#則不同,它的設(shè)計初衷就是一類著眼于小處的高效嵌入式控制語言。嵌入式虛擬機(簡稱EVM)允許B#語言運行在多種不同平臺之上,且內(nèi)存占用量僅為24 k——遠低于我們之前提到的其它軟件包運行要求。 B#語言與C#在某種程度上比較類似(如果大家或者下轄技術(shù)團隊曾經(jīng)開發(fā)過微軟.NET項目,那么對C#肯定不會陌生)。不過相較于C#,B#剔除了相當一部分在嵌入式項目中用不到的特性,并加入了對實時控制功能的支持——這一點在實際使用環(huán)境下顯然非常重要。 如果大家的項目如果大家的開發(fā)項目未來會運行在輕量級嵌入式平臺之上,其規(guī)模與復(fù)雜度皆低于Raspberry Pi,那么B#絕對是個值得認真考慮的編程語言選項。 匯編語言 如果大家希望嚴格遵循比較傳統(tǒng)的設(shè)計思路,或者需要盡可能讓自己的項目顯得比較緊湊,那么匯編程序就是達成目標的不二之選。匯編語言能夠構(gòu)建并打包純粹的機器碼,從而保證大家在處理器之上擁有最為理想的執(zhí)行效率。好消息是其對性能的要求被控制在最低水平,而且技術(shù)高超的行家能夠利用匯編語言實現(xiàn)很多在其它編程機制中根本不存在的優(yōu)化技巧。 不過壞消息是,匯編語言的編程工作無法借力于網(wǎng)絡(luò):大家?guī)缀跽也坏饺魏螌嵱霉ぞ邅韼椭约壕境鲩_發(fā)成果中的各類錯誤。除此之外,匯編語言代碼以及相關(guān)程序編寫技能往往沒有任何承接性。具體來講,我們能夠針對一種處理器編寫出相關(guān)代碼,但這并不代表我們能夠面向其它處理器編寫出擁有同樣功能的代碼。 對于鐵桿程序員以及希望擁有終極優(yōu)化效果的產(chǎn)品來講,匯編語言能夠?qū)⑵潴w積控制在最低水平且保證其中不包含任何其它環(huán)境因素。不過可以肯定的是,匯編語言絕對不是構(gòu)建原型方案的最佳方式——如果大家擁有較為充裕的空間及處理性能,那么請優(yōu)先使用高級語言,現(xiàn)代語言中的諸多優(yōu)勢還是能夠幫上忙的。 Forth Forth是另一種專門針對嵌入式系統(tǒng)編程工作做出設(shè)計與優(yōu)化的語言。雖然它的主要定位在于實現(xiàn)系統(tǒng)層級上的編程,但Forth還擁有另一大不可替代的優(yōu)勢:它有點像是編程世界中的黑話。舉例來講,假如說某個群體以世界語作為母語,并傾向于使用它來跟我們交流,那么不懂世界語就會讓我們處于非常尷尬的境地。而在編程世界當中,F(xiàn)orth就是這樣一種等同于世界語的存在。 Forth語言屬于面向堆棧語言。如果大家經(jīng)常使用那種老式惠普計算器(就是那種提供RPN操作模式的產(chǎn)品),那么肯定會對Forth具備一定程度的理解。作為一種誕生于上世紀七十年代的語言,F(xiàn)orth能夠在具備相關(guān)能力的程序員手中實現(xiàn)可觀的生產(chǎn)力與執(zhí)行效率提升效果——而且其他人根本無法使用甚至閱讀由其編寫出的成果。 如果大家所在的開發(fā)團隊中存在著大量Forth程序員,那么請享受由此帶來的完全不同的工作體驗。而如果大家對Forth一無所知而又打算開發(fā)一款全新嵌入式項目,且樂于接受這一語言帶來的開發(fā)學(xué)習(xí)曲線,那么也不妨加以嘗試。不過如果各位身邊并不具備現(xiàn)成的Forth程序員儲備,同時又希望快速構(gòu)建出原型設(shè)計方案,那么請直接選擇其它語言。 |
|