0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

嵌入式C編程庫的創(chuàng)建經(jīng)驗(yàn)分享

5RJg_mcuworld ? 來源:互聯(lián)網(wǎng) ? 作者:佚名 ? 2017-11-03 14:58 ? 次閱讀

庫,這可是大殺器!一個(gè)的設(shè)備程序如果完美庫化。



它意味著:

1.所有工程師在移植或創(chuàng)建該設(shè)備驅(qū)動(dòng)時(shí),花費(fèi)的代價(jià)超小。

2.隨著使用者的增多,它飽經(jīng)考驗(yàn),不斷趨于穩(wěn)定,變?yōu)楫?dāng)之無愧的公共代碼。

3.庫對外的接口(函數(shù)名及其參數(shù)聲明)是不變的,當(dāng)所有常用設(shè)備都實(shí)現(xiàn)庫化時(shí),它帶來另外一個(gè)好處,應(yīng)用層的移植、創(chuàng)建、修改維護(hù)的時(shí)間耗費(fèi)也會(huì)劇烈減少。應(yīng)用層的跨平臺(tái)無縫移植不是傳說,當(dāng)它所依賴的所有外圍設(shè)備通通在不同平臺(tái)庫化的時(shí)候,應(yīng)用層的實(shí)現(xiàn),就像在寫java代碼一樣。

4.庫意味這公司核心代碼的安全,庫代碼只掌握在核心工程師手里,應(yīng)用層的程序即使丟失也是無礙。

5.新人對于這些基于庫案子更快上手,一來有庫幫助文檔的說明,二來不必也無法關(guān)心底層細(xì)節(jié),專注于應(yīng)用開發(fā)。

6.提供給客戶二次開發(fā),你可以把硬件和外設(shè)驅(qū)動(dòng)的庫交給客戶,讓其二次開發(fā)。

7.通信協(xié)議的庫化,將使通信系統(tǒng)類的產(chǎn)品更加安全,至少不會(huì)被離職的工程師破壞,比如RFID的扣款充值。

8. ......

怎么樣,它使老板心動(dòng),工程師百味雜陳。

當(dāng)然,有些工程師會(huì)想到,庫可以使他脫離繁瑣的底層驅(qū)動(dòng)工作,進(jìn)行更高層次的工作。

庫的創(chuàng)建要想搞得好,有以下幾個(gè)條件

1.提供給客戶的只有.h檔和.lib檔。

2.所有.h檔中沒有define,編譯條件對于.lib檔來說只是一個(gè)笑話。

3.所有.h檔中沒有extern變量,如果有,這意味著系統(tǒng)只能創(chuàng)建一個(gè)這種設(shè)備。比如蜂鳴器驅(qū)動(dòng),如果extern變量,就意味著整個(gè)系統(tǒng)只允許一個(gè)蜂鳴器。

4.完善而詳細(xì)的使用幫助文檔??蓞⒖?a href="http://srfitnesspt.com/tags/keil/" target="_blank">keil的hlp文檔格式。

5.簡單的使用該.h檔的demo程序讓人參考。

6.“動(dòng)態(tài)鏈接”庫代碼,簡言之,沒用到的接口函數(shù)代碼不會(huì)被鏈接器搞到最終的二進(jìn)制檔中。

7.還有一點(diǎn),盡量的平臺(tái)無關(guān)性,它不依賴于任何寄存器或者其他和平臺(tái)相關(guān)的東西。

要達(dá)到上述的目的,通常會(huì)使庫有如下特點(diǎn)

1.結(jié)構(gòu)體指針

2.大量的回調(diào)函數(shù)指針。

3.豐富的接口。

4.庫源碼的.c檔將按接口函數(shù)拆分成更多的.c檔,這為了實(shí)現(xiàn)鏈接時(shí)代碼空間最小化。

庫的缺點(diǎn)也是有的

1.它會(huì)使設(shè)備速度變慢一些,多了幾層間接取址的消耗。但對于32位機(jī),對于它帶來的便利,還是可接受的。

2.它會(huì)使code空間消耗相對更大一些,但請相信我,對于一整個(gè)中大型系統(tǒng)而言,它會(huì)使代碼量不升反降,因?yàn)榇笙到y(tǒng)中有非常多的重復(fù)冗余代碼。這方面我個(gè)人的經(jīng)驗(yàn),降的不是一般的多,簡直到了一個(gè)難以置信的程度。

早期的8位機(jī),51平臺(tái)上其實(shí)不能很好地實(shí)現(xiàn)完美的庫,至少是不能實(shí)現(xiàn)一個(gè)跨機(jī)型的底層設(shè)備驅(qū)動(dòng)庫。近年來隨著32位機(jī)的興起,庫漸漸地受到越來越多工程師的青睞。這里面最本質(zhì)的原因在于,51架構(gòu)的棧是靜態(tài)編譯的,局部變量和傳參的棧也是靜態(tài)的,函數(shù)無法重入。而多數(shù)的32位機(jī)都是壓棧傳參的方式。當(dāng)然,51速度慢也是重要的原因之一。

如果有熟悉面向?qū)ο笳Z言或者linux驅(qū)動(dòng)的朋友,你大概就明白一個(gè)好的庫是什么樣子的了。庫就像是面向?qū)ο笾械念?,至于linux底層驅(qū)動(dòng)的代碼,那就是函數(shù)指針和結(jié)構(gòu)體指針的世界。C的精華在指針,在里面得到完美的詮釋。

當(dāng)然,庫的代價(jià)也是有的

1.它會(huì)使設(shè)備速度變慢一些,多了幾層取地址的消耗。但對于32位機(jī),對于它帶來的便利,還是可接受的。

2.它會(huì)使code消耗便大一些,但請相信我,對于一個(gè)中大型系統(tǒng)而言,它會(huì)使代碼不升反降,因?yàn)榇笙到y(tǒng)中有非常多的重復(fù)冗余代碼。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 嵌入式C編程
    +關(guān)注

    關(guān)注

    0

    文章

    1

    瀏覽量

    3838

原文標(biāo)題:嵌入式C編程經(jīng)驗(yàn)細(xì)談: 你庫了嗎?

文章出處:【微信號:mcuworld,微信公眾號:嵌入式資訊精選】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    嵌入式C++編程的相關(guān)資料分享

    編程特性來構(gòu)建嵌入式系統(tǒng)您將了解如何將您的系統(tǒng)與外部外圍設(shè)備以及使用驅(qū)動(dòng)程序的有效方式集成指導(dǎo)您測試和優(yōu)化代碼以獲得更好的性能并實(shí)現(xiàn)有用的設(shè)計(jì)模式將了解如何使用 Qt,這是用于構(gòu)建嵌入式系統(tǒng)的流行 GUI
    發(fā)表于 11-09 08:26

    嵌入式網(wǎng)絡(luò)編程+嵌入式Linux系統(tǒng)

    D2.25嵌入式網(wǎng)絡(luò)編程+嵌入式Linux系統(tǒng)一、Linux操作系統(tǒng)安裝與使用(命令)二、Linux開發(fā)工具(gcc、gdb、make)三、Linux系統(tǒng)編程(文件、進(jìn)程、線程、網(wǎng)路、
    發(fā)表于 12-22 07:10

    汽車電子的嵌入式軟件編程接口設(shè)計(jì)

    汽車電子的嵌入式軟件編程接口設(shè)計(jì)  本文介紹了一種支持汽車電子的嵌入式軟件平臺(tái)編程接口
    發(fā)表于 02-09 11:46 ?43次下載

    嵌入式c語言編程(由淺入深)

    本內(nèi)容詳細(xì)介紹了嵌入式c語言編程的各項(xiàng)知識,包括嵌入式c語言編程
    發(fā)表于 11-02 14:37 ?0次下載
    <b class='flag-5'>嵌入式</b><b class='flag-5'>c</b>語言<b class='flag-5'>編程</b>(由淺入深)

    嵌入式C編程

    嵌入式C編程,非常有用的資料,介紹嵌入式C語言編程
    發(fā)表于 12-29 17:29 ?0次下載

    嵌入式C編程與ATmelAVR

    嵌入式C編程與ATmelAVR 非常好的資源
    發(fā)表于 12-29 17:56 ?0次下載

    C嵌入式系統(tǒng)編程

    C嵌入式系統(tǒng)編程
    發(fā)表于 10-23 16:27 ?14次下載

    嵌入式c編程語言入門與深入

    嵌入式c編程語言入門與深入
    發(fā)表于 10-24 08:38 ?61次下載
    <b class='flag-5'>嵌入式</b><b class='flag-5'>c</b><b class='flag-5'>編程</b>語言入門與深入

    嵌入式常用的c標(biāo)準(zhǔn)

    C標(biāo)準(zhǔn)函數(shù)是所有符合標(biāo)準(zhǔn)的頭文件(head file)的集合,以及常用的函數(shù)實(shí)現(xiàn)程序,例如I/O 輸入輸出和字符串控制。不像 COBOL、Fortran 和 PL/I等編程語言,
    發(fā)表于 02-06 17:28 ?5298次閱讀
    <b class='flag-5'>嵌入式</b>常用的<b class='flag-5'>c</b>標(biāo)準(zhǔn)<b class='flag-5'>庫</b>

    嵌入式技能樹】

    程師嵌入式硬件工程師通用技能樹軟件C/C++語言編程經(jīng)驗(yàn)、編程能力、應(yīng)用開發(fā)、OOP面向?qū)ο?/div>
    發(fā)表于 10-21 10:21 ?16次下載
    【<b class='flag-5'>嵌入式</b>技能樹】

    嵌入式實(shí)驗(yàn)】《嵌入式數(shù)據(jù) sqlite 移植及使用》

    的基本方法,掌握 sqlite 數(shù)據(jù)軟件移植的步驟,掌握 sqlite 開發(fā)的兩種方式 — 命令模式和 C代碼開發(fā)模式 的使用方法,并編程實(shí)現(xiàn)簡單通訊錄查詢實(shí)驗(yàn)。二.實(shí)驗(yàn)內(nèi)容實(shí)驗(yàn)4.1 移植
    發(fā)表于 10-21 10:51 ?6次下載
    【<b class='flag-5'>嵌入式</b>實(shí)驗(yàn)】《<b class='flag-5'>嵌入式</b>數(shù)據(jù)<b class='flag-5'>庫</b> sqlite 移植及使用》

    嵌入式網(wǎng)絡(luò)編程+嵌入式Linux系統(tǒng)

    嵌入式網(wǎng)絡(luò)編程+嵌入式Linux系統(tǒng)一、 Linux操作系統(tǒng)安裝與使用(命令)二、 Linux開發(fā)工具(gcc、gdb、make)三、 Linux系統(tǒng)編程(文件、進(jìn)程、線程、網(wǎng)路、數(shù)據(jù)
    發(fā)表于 11-02 14:51 ?23次下載
    <b class='flag-5'>嵌入式</b>網(wǎng)絡(luò)<b class='flag-5'>編程</b>+<b class='flag-5'>嵌入式</b>Linux系統(tǒng)

    C嵌入式編程設(shè)計(jì)模式

    C嵌入式編程設(shè)計(jì)模式1 嵌入式系統(tǒng)有何特殊之處 11 嵌入式設(shè)計(jì)的約束 12 嵌入式工具 1
    發(fā)表于 11-03 15:36 ?17次下載
    <b class='flag-5'>C</b><b class='flag-5'>嵌入式</b><b class='flag-5'>編程</b>設(shè)計(jì)模式

    C嵌入式編程設(shè)計(jì)模式》讀書筆記

    C嵌入式編程設(shè)計(jì)模式》第一章 什么是嵌入式編程嵌入式系統(tǒng)的基本知識面向?qū)ο?/div>
    發(fā)表于 11-03 16:06 ?13次下載
    《<b class='flag-5'>C</b><b class='flag-5'>嵌入式</b><b class='flag-5'>編程</b>設(shè)計(jì)模式》讀書筆記

    嵌入式C++編程

    編程特性來構(gòu)建嵌入式系統(tǒng)您將了解如何將您的系統(tǒng)與外部外圍設(shè)備以及使用驅(qū)動(dòng)程序的有效方式集成指導(dǎo)您測試和優(yōu)化代碼以獲得更好的性能并實(shí)現(xiàn)有用的設(shè)計(jì)模式將了解如何使用 Qt,這是用于構(gòu)建嵌入式系統(tǒng)的流行 GUI
    發(fā)表于 11-04 10:36 ?10次下載
    <b class='flag-5'>嵌入式</b><b class='flag-5'>C</b>++<b class='flag-5'>編程</b>