張智慧



摘 要: 分層架構已經(jīng)在軟件開發(fā)中得到廣泛應用,促進了軟件開發(fā)的工程化管理,提高了軟件的質量和效率。文將多層軟件框架模型引入到嵌入式應用開發(fā),按照系統(tǒng)功能進行分層隔離封裝,降低功能模塊間的耦合關系,設計出包含應用管理層、算法協(xié)議層、功能拓展層和硬件驅動層等四層架構模型,明確各層間的接口和調用關系,較好地解決了軟件開發(fā)的復用性和可靠性問題。文章給出了應用案例。
關鍵詞: 多層模型; 嵌入式系統(tǒng); 軟件開發(fā); 可靠性
中圖分類號:G424 文獻標志碼:A 文章編號:1006-8228(2017)04-17-04
Abstract: The layered architecture has been widely used in software development, to facilitate the engineering management of software development, and improve the quality and efficiency of the software. In this paper, the multilayer software framework model is used in the development of embedded application software, and the functions of the system are separated and encapsulated to reduce the coupling between the modules. The four-layer architecture model is designed, which includes application management layer, algorithm protocol layer, function extension layer and hardware driver layer, the interface and calling method between different layers are defined, and the problems of reusability and reliability of embedded application software development are solved quite good, which are shown with a case study.
Key words: multilayer model; embedded system; software development; reliability
0 引言
隨著嵌入式應用的快速發(fā)展,嵌入式軟件系統(tǒng)的規(guī)模和復雜度日益增長,對軟件開發(fā)的質量和效率提出更高要求。從軟件工程角度來看,嵌入式軟件開發(fā)主要面臨兩類問題,一是如何盡可能地提高軟件的可復用性,二是如何適應用戶需求、硬件環(huán)境變化快速調整。分層架構已經(jīng)在軟件開發(fā)中得到廣泛應用,能夠有效降低功能模塊間的耦合關系,提高軟件開發(fā)效率,如基于物理架構劃分的C/S和B/S模式,基于邏輯架構劃分的MVC、MVP、MVVM模式等。隨著處理器性能的提升、對外接口的豐富,傳統(tǒng)軟件開發(fā)方法已經(jīng)遠遠不能滿足嵌入式應用軟件的開發(fā)要求。本文研究探討了多層模型在嵌入式軟件開發(fā)中體系架構設計方法,并給出了應用案例。
1 多層軟件開發(fā)模型
在軟件開發(fā)中,合理確定軟件體系架構的重要性已經(jīng)遠遠超過了特定算法和數(shù)據(jù)結構的選擇。軟件體系架構設計包含了從軟件框架、功能設計、程序開發(fā)到應用軟件部署的完整解決方案。通過分層技術,很多復雜的問題得以分割、簡化,轉化成具體的程序實現(xiàn)。分析嵌入式軟件開發(fā)特點,合理設計軟件體系架構、劃分功能層次,有助于提高軟件開發(fā)質量。
1.1 軟件開發(fā)中的分層技術
分層技術就是通過對用戶需求問題進行梳理,抽象出軟件結構中不同功能領域,合理界定內部各層次之間的依賴關系,簡化功能模塊的開發(fā)實現(xiàn),最終將系統(tǒng)問題轉變?yōu)檐浖O計,支持軟件系統(tǒng)需要完成的所有功能。在軟件開發(fā)過程中,面向的應用場景越復雜,解決問題需要的層次劃分就越多,層次間的依賴關系、接口關系設計難度就越大。分層方法有多種,但并沒有具體的標準,在保證軟件功能實現(xiàn)前提下,一是各層解決不同的問題,簡化軟件實現(xiàn),能夠為上層應用提供支撐;二是某一層的軟件設計出現(xiàn)問題,只會影響到該層次的上下結構,不會影響軟件系統(tǒng)的整體;三是每層內部再進行縱向或橫向上的功能劃分,盡量實現(xiàn)軟件功能的高內聚、低耦合。
1.2 嵌入式系統(tǒng)的分層結構
通常將嵌入式應用系統(tǒng)從技術結構上分為四個層次,包括硬件平臺、BSP及設備驅動層、調度系統(tǒng)層和應用層,如圖1所示。
⑴ 硬件平臺層。核心微處理器包括嵌入式微處理器(如ARM系列),以及基于DSP或CPLD/FPGA的開發(fā),微處理器一般具有豐富的對外接口,如UART、I2C等。外圍功能電路包括鍵盤、數(shù)碼管、液晶屏、控制電路、高頻電子、開關電源等。
⑵ 設備驅動層。實現(xiàn)處理器片內硬件外設和片外硬件外設驅動的API,同時提供底層算法API,包括GPIO、定時器、ADC/DAC、SPI、I2C、CAN等片內外設的驅動及API實現(xiàn),片外外設(水平儀、溫度傳感器、UART)的驅動及API實現(xiàn)。設備驅動層相對比較獨立,一般是基于操控底層硬件的低級語言建立硬件的抽象層,為上層應用提供接口。
⑶ 調度系統(tǒng)層。采用嵌入式操作系統(tǒng)(如Linux、android等)或直接編寫調度器。一般包括嵌入式操作系統(tǒng)和部分基礎應用裁剪,或在現(xiàn)有調度器(如Protothread)基礎上編寫內存管理、電源管理等專用系統(tǒng)。
⑷ 應用層。包括人機接口與GUI開發(fā)、核心算法及業(yè)務應用,很多應用還包括數(shù)據(jù)庫、網(wǎng)絡通信、RFID、藍牙通信等應用開發(fā)。
1.3 嵌入式應用軟件開發(fā)的分層模型
嵌入式應用軟件對功能、可靠性有著嚴格的要求。傳統(tǒng)結構化的軟件開發(fā)方式,主要是針對外設硬件電路功能,完成相應的軟件功能模塊開發(fā),當硬件或應用需求發(fā)生變化時,很多模塊都需要重新開發(fā),代碼重用性低,開發(fā)調試難度大,軟件的適應性和維護性也不好。隨著嵌入式應用系統(tǒng)越來越復雜,這一矛盾變得日益突出。采用分層技術,對嵌入式應用軟件系統(tǒng)進行邏輯上的合理設計,成為提高軟件開發(fā)效率、執(zhí)行效率和維護效率的關鍵。
按照“高內聚,低耦合”的原則,對嵌入式應用軟件系統(tǒng)輸入/輸出、應用調度、設備驅動、算法模型、接口訪問、網(wǎng)絡通信和數(shù)據(jù)庫等功能進行重新劃分,降低應用邏輯和業(yè)務模型、軟件功能和硬件電路的耦合性和依賴關系,可以區(qū)分為應用管理層、算法協(xié)議層、功能拓展層、硬件驅動層等四個層次。四層結構模型如圖2所示。
從圖2可以看出,經(jīng)過重新分層后,使得整個應用程序的結構變得更加清晰和靈活,一個成熟的模型算法能夠支持多個應用邏輯,一個成熟的軟件功能模塊能夠適應不同的硬件環(huán)境,最大限度地提高了軟件的可復用性。對于一個項目,采用上述分層模型后,其后期維護擴展只需對應用管理層進行修改并根據(jù)需要完善功能拓展層;新上項目可以復用算法協(xié)議層和功能拓展層的相關功能模塊,大大簡化項目開發(fā),而且隨著模塊的不斷積累,成熟的功能模塊會越來越完善,軟件開發(fā)質量和效率能夠得到很大提升。由于在硬件驅動層實現(xiàn)了硬件無關,故只需完善硬件驅動層就可以實現(xiàn)不同硬件之間的移植。
2 基于C語言的軟件框架設計
由于C語言具備良好的跨平臺特性,并提供了許多低級處理的功能,在嵌入式應用開發(fā)中得到了廣泛應用。但C語言作為一種結構化的程序設計語言,主要是依據(jù)功能進行模塊劃分,在實現(xiàn)分層模型的過程中,需要制定相應的開發(fā)策略。
2.1 框架設計
按照分層模型,在軟件開發(fā)文件規(guī)劃時,要避免不同層次的功能模塊放在同一個實現(xiàn)文件中,影響代碼重用,同時由于C語言沒有面向對象的封裝特性,數(shù)據(jù)和功能函數(shù)相對分離,應盡量將操作數(shù)據(jù)相同的函數(shù)放在一起。
⑴ 應用管理層。主要包括用戶主程序main以及實現(xiàn)輸入交互、任務調度、時間管理等功能模塊,通過調度相應的功能模塊,實現(xiàn)實際任務的運行。一般包括以下幾部分:
初始化各類硬件;
初始化各類軟件參數(shù);
While(1) {
調用功能函數(shù)(算法協(xié)議層相關功能模塊);
響應中斷;
按照業(yè)務邏輯修改狀態(tài)數(shù)據(jù);
等待; }
應用管理層的各功能模塊可以放在一個main.c文件中,也可以放在不同的實現(xiàn)文件,在main.c中進行引用。
⑵ 算法協(xié)議層。主要包括模型算法、協(xié)議解析、文件管理、數(shù)據(jù)庫管理等功能模塊,實現(xiàn)系統(tǒng)應用所有功能。該層功能模塊從應用管理層接收狀態(tài)參數(shù),按照業(yè)務處理邏輯進行處理,并調用功能拓展層的功能模塊,完成系統(tǒng)運行功能,并返回狀態(tài)和結果數(shù)據(jù)。
核心算法和業(yè)務應用設計基本上都在該層完成,也包括已有的協(xié)議棧、軟件包、標準庫等功能模塊。
⑶ 功能拓展層。主要實現(xiàn)器件的無關性,提供各種拓展功能和器件的通用性處理、接口訪問等功能模塊。該層功能模塊主要實現(xiàn)特定器件相關的通用功能,如LCD的線、圓、矩形等處理,一般不同的器件采用不同的實現(xiàn)文件,通過文件名進行區(qū)分。
⑷ 硬件驅動層。主要實現(xiàn)硬件的無關性,提供硬件的基本功能操作。如LCD的初始化、定位、寫點、寫字節(jié)等。為了保證代碼的通用性,針對不同硬件的相同功能的外部函數(shù)都盡量一致,一種特定硬件對應一個實現(xiàn)文件,并通過文件名進行區(qū)分。
2.2 模塊化設計
標準的C語言并不提供軟件框架管理,需要用戶自己來管理工程文件,實現(xiàn)對各類功能模塊的分層管理。
⑴ 工程文件結構。將系統(tǒng)功能模塊按照文件夾在工程項目內進行組織,一般應用管理層的功能模塊放在根目錄,其他三個層的功能模塊分別存放在ModelFuc、ComFuc、Hardrv文件夾,文件的命名遵循統(tǒng)一的規(guī)范。開發(fā)過程中,可以充分利用分層模型的優(yōu)勢,各層功能的開發(fā)人員在不同的文件夾內進行并行工作,實現(xiàn)工程化管理。每層功能模塊的開發(fā)調用下一層的功能模塊,盡量避免交叉調用或越級調用。
⑵ 模塊內部設計。為了實現(xiàn)模塊化設計的高內聚性,應少用或不用全局變量,盡量通過函數(shù)參數(shù)來傳遞數(shù)據(jù)。在編程過程中,要采用一定的技術措施,提高代碼的可重用性,比如在頭文件中增加防止重復包含處理,在函數(shù)內部增加錯誤處理機制等。
3 應用案例
本案例是利用角速度傳感器制作一個電子羅盤,在LCD顯示屏上實時顯示手持設備的方位。由于已經(jīng)開發(fā)過類似的應用,硬件也沿用了原來的硬件設計,算法協(xié)議層、功能拓展層、硬件驅動層的功能模塊直接復用原來的代碼,通過在應用管理層實現(xiàn)羅盤顯示位置、大小和延時設定,增加顯示X、Y、Z軸數(shù)值,就完成了項目開發(fā),而且運行穩(wěn)定可靠。
整個工程文件結構如圖3所示。Hardrv文件夾存放LCD、角速度傳感器,以及電源設備的硬件驅動模塊。ComFuc文件夾存放LCD畫圖、字體顯示、羅盤數(shù)值轉換等功能模塊。ModelFuc存放羅盤顯示功能模塊,在進行模塊設計時已經(jīng)考慮到復用,可以通過參數(shù)設定羅盤顯示大小比例、指針顯示位置。在compass.c模塊中,讀取傳感器的X、Y、Z軸數(shù)值,調用羅盤顯示功能模塊,并調用字體顯示功能進行各個方向軸的數(shù)值顯示,實現(xiàn)電子羅盤應用功能。LCD顯示功能在各層分部的示例代碼如下:
應用管理層→uint Show_Compass( uint x, uint y, uint
z,uint pcolor); //顯示當前x、y、z軸數(shù)值對應的羅盤,顯示區(qū)域大小設為全局變量,完成顯示邏輯轉換后調用畫羅盤指針函數(shù)。
算法模型層→uint Draw_Compass(uint cx, uint cy, uint
len, uint angle, uint pcolor); //畫羅盤指針,cx、cy為中心位置,轉換成直角坐標后調用畫線函數(shù)。
功能拓展層→uint Lcd_Line(uint x1, uint y1, uint x2,
uint y2, uint pcolor);//畫線,調用畫點函數(shù)。
硬件驅動層→uint Lcd_Pixel(uint x, uint y, uint pcolor);
//驅動LCD進行畫點。
從該案例可以看出,硬件驅動層實現(xiàn)對硬件功能的封裝,功能拓展層實現(xiàn)軟件功能的通用化,對硬件功能和數(shù)據(jù)的進一步封裝,提供簡單有效的訪問手段,能夠供不同的業(yè)務處理使用。算法協(xié)議層對業(yè)務邏輯進行封裝,能夠成為可直接解決應用問題的功能模塊。應用管理層負責整個應用系統(tǒng)的調度、控制和管理。層與層之間耦合性大大降低,提高了軟件功能模塊的開發(fā)效率和可復用性。
4 結束語
多層模型提供了嵌入式應用軟件開發(fā)良好的架構,功能模塊劃分更加合理、規(guī)范,軟件可復用性大大提高。本文給出的軟件框架設計,能夠有效解決使用C語言進行復雜系統(tǒng)編程時框架結構分散問題,使得開發(fā)人員的思路更加清晰,便于工程化管理。在嵌入式應用軟件開發(fā)過程中采取多層模型,具有較高的可擴展性,能夠不斷積累成熟軟件功能模塊,降低軟件后期維護難度,提高項目開發(fā)的質量和效率。
參考文獻(References):
[1] 李小遐,劉惠梅.C語言程序設計能力教程[M].北京理工大學出版社,2011.
[2] 程欣宇,張麗,王忠德.數(shù)據(jù)結構實驗的三層模型[J].計算機教育,2014.12:65-67
[3] 陳偉.基于MVC模式的安卓系統(tǒng)工程結構設計[J].中國科技信息,2016.19:47-48
[4] 楊柯.分層技術在計算機軟件開發(fā)中的應用效果分析[J].軟件,2013.10:47-48
[5] 林越,王翠珍.淺談面向對象開發(fā)思想與軟件設計架構分析[J].信息通信,2016.3:152-154