剛開始工作的兩年,我做項(xiàng)目寫代碼不會考慮代碼擴(kuò)展、移植、模塊化等,導(dǎo)致項(xiàng)目有新增功能、或修改的時(shí)候不知如何下手。今天分享一篇肖遙整理的關(guān)于設(shè)計(jì)模式的文章,希望對大家有幫助。
工作有些年了,每每看到一些朋友會問,設(shè)計(jì)模式需要學(xué)嗎?好像做嵌入式的從沒遇到過需要用設(shè)計(jì)模式的,所以一直沒系統(tǒng)學(xué)習(xí),但是我也知道這個(gè)很重要,久而久之,到頭來還是沒學(xué)。 這里我說一下自己的看法和思考,來看看一些問題。
1
什么是設(shè)計(jì)模式?
設(shè)計(jì)模式是代表了開發(fā)人員不斷積累的最佳的實(shí)踐,是軟件開發(fā)人員在軟件開發(fā)過程中面臨的一般問題的最優(yōu)解決方案。
也就是說,經(jīng)過了不斷的發(fā)展,不同的問題或者方案有對應(yīng)的一套法子,而這個(gè)法子被總結(jié)成了這么幾十種通用模式,我們?nèi)绻龅搅司蛯?yīng)著去套用就可以了。 當(dāng)然那幾大開發(fā)原則和二十幾種設(shè)計(jì)模式大家還是隨便去找都可以找到說明的,筆者就不多說了(我也只用到了其中幾種),大家自行學(xué)習(xí)為好。
2
開發(fā)中為什么很少用設(shè)計(jì)模式?
在平時(shí)項(xiàng)目開發(fā)中,我們很少使用設(shè)計(jì)模式,我感覺這個(gè)現(xiàn)象還是很正常的,不是說工作中沒用到設(shè)計(jì)模式,而是大多數(shù)情況下我們項(xiàng)目中沒想那么多,更多的是做一些需求更改,而忽略本質(zhì)。
設(shè)計(jì)模式的目的是提供可拓展性和可維護(hù)性,但是我們開發(fā)的項(xiàng)目本身,大部分都是固定寫死的,邏輯單一,我們開發(fā)的模塊也并不在其他的位置或項(xiàng)目中復(fù)用,目的很明確就是做當(dāng)前的業(yè)務(wù)。 平時(shí)開發(fā)中用到設(shè)計(jì)模式的地方很少,但是框架就不同的了,框架必須適應(yīng)不同的項(xiàng)目,具備高彈性和拓展性。他們要能適應(yīng)各種不同的環(huán)境,所以,設(shè)計(jì)模式在框架設(shè)計(jì)中處處可見。 假如一開始在大公司或者接手一個(gè)接近成熟的項(xiàng)目時(shí),那大概率會負(fù)責(zé)一些小模塊或者細(xì)分領(lǐng)域的開發(fā);而在小公司或者是幾乎從零開始做項(xiàng)目的時(shí)候,可能我們本身還不夠去設(shè)計(jì)一個(gè)符合項(xiàng)目長期規(guī)劃的架構(gòu),最終導(dǎo)致寫的代碼比較亂,維護(hù)性差。 所以在嵌入式開發(fā)中,當(dāng)我們有了一定的基礎(chǔ)和項(xiàng)目經(jīng)驗(yàn)的時(shí)候,我們就會想著,嗯,一個(gè)好的架構(gòu)多么重要啊,或者我需要去好好學(xué)一下設(shè)計(jì)模式了。
3
嵌入式開發(fā)一定要學(xué)設(shè)計(jì)模式嗎 ?
可以這么說,設(shè)計(jì)模式為拓展而生。
平時(shí)項(xiàng)目中的業(yè)務(wù)邏輯代碼,大部分功能是死的,是專為這個(gè)場景而生的,不會在另外的場景中出現(xiàn),這種業(yè)務(wù)的開發(fā),是不需要設(shè)計(jì)模式的。 但是如果需求有變化,我們一般可能就直接修改源代碼了,這樣實(shí)際上帶來了一定的修改成本,而為了一個(gè)項(xiàng)目中可能不明確的未來變化,而精心設(shè)計(jì)擴(kuò)展性很高的架構(gòu),成本也是顯而易見的,所以,這是一個(gè)取舍。 當(dāng)然,從長期來看,一個(gè)好的設(shè)計(jì)是值得的,畢竟與其不斷的修改新的需求,還不如一勞永逸,這樣開發(fā)人員才能從各個(gè)方面高效去開發(fā)了。 在嵌入式軟件開發(fā)中,當(dāng)軟件系統(tǒng)到達(dá)一定的復(fù)雜程度時(shí),設(shè)計(jì)模式就顯得尤為重要。雖然搞嵌入式的常常是基于一些16位/32位/64位單片機(jī)開發(fā),而且這些可能受一些硬件方面的限制,但是單片機(jī)軟件也是可以遵循軟件工程的基本原則來進(jìn)行架構(gòu)的。 從代碼組織的角度比如組件化、分層、去耦等等,或者從設(shè)計(jì)角度比如基于消息隊(duì)列、事件驅(qū)動等等,都是有因可循的。 所以對于這個(gè)問題,嵌入式開發(fā)最好是要學(xué)設(shè)計(jì)模式,這里鼓勵大家多看看重構(gòu)、設(shè)計(jì)模式、面向?qū)ο蟮腃等方面的書籍。
4
設(shè)計(jì)模式該怎么學(xué)?
前面說了那么多,設(shè)計(jì)模式是什么,嵌入式中哪里用到了設(shè)計(jì)模式,設(shè)計(jì)模式到底需不需要學(xué)等等,好,那你告訴我到底怎么學(xué)!
這里我想分一些情況來說,關(guān)于這個(gè)問題,設(shè)計(jì)模式怎么學(xué)習(xí),得看你的程度、你主要解決什么問題、你負(fù)責(zé)的部分而定。 若你的編程水平或者學(xué)習(xí)的程度還沒到那(還在學(xué)習(xí)怎么編程階段),看了自然是懵逼的,這個(gè)時(shí)候還是好好補(bǔ)補(bǔ)基礎(chǔ)知識,這些還用不到。 若在項(xiàng)目當(dāng)中,你解決的大部分是一些業(yè)務(wù)邏輯,這種情況能用的設(shè)計(jì)模式不多,因?yàn)樾枰氖菢I(yè)務(wù)模式,也就是參考設(shè)計(jì)模式原理,自己設(shè)計(jì)業(yè)務(wù)模式改改需求啥的,就沒必要了。 若你負(fù)責(zé)或參與應(yīng)用框架或與其相關(guān),那幫助就大了,這個(gè)時(shí)候用什么設(shè)計(jì)模式,怎么去設(shè)計(jì)就要考驗(yàn)功底了。 當(dāng)然,不管怎么說,只要有時(shí)間即使是你目前程度還不到,你也可以學(xué)習(xí)設(shè)計(jì)模式使自己提升程度,但得一步一步來,穩(wěn)中進(jìn)步。 這個(gè)學(xué)習(xí)也不是一次性把所有的都學(xué)習(xí)了,這樣其實(shí)也很難掌握,可能只是知其表而已,一般先從某個(gè)與你要處理的問題相關(guān)或者常會遇到的模式開始學(xué)起,一次學(xué)一個(gè),學(xué)的深一些。 大部分人最常提的是單例、工廠、策略這幾個(gè),比如一個(gè)功能,要求既要支持串口通信,又要支持TCP通信,而對調(diào)用方來說最好不要知道它們的區(qū)別,這就是典型的策略模式場景。 這種比較常見的情況,很多項(xiàng)目中都可能遇到,因此不可能不學(xué),網(wǎng)上也有很多經(jīng)驗(yàn)分享,還有很多教程例子,這個(gè)時(shí)候也不可能學(xué)不會。
5
總結(jié)
到此,你覺得設(shè)計(jì)模式有沒有用?
每個(gè)人的情況不同,學(xué)習(xí)過程不一定是這樣,做的工作內(nèi)容肯定也不一樣,關(guān)鍵點(diǎn)是只要你在這行,在寫代碼,那么一般一定用得到其中幾個(gè)模式,等你學(xué)會幾個(gè),并且常用,時(shí)間久了自然就明白了。
原文標(biāo)題:嵌入式開發(fā)中為什么很少用設(shè)計(jì)模式?
文章出處:【微信公眾號:strongerHuang】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
責(zé)任編輯:haq
-
嵌入式
+關(guān)注
關(guān)注
5143文章
19575瀏覽量
315708
原文標(biāo)題:嵌入式開發(fā)中為什么很少用設(shè)計(jì)模式?
文章出處:【微信號:strongerHuang,微信公眾號:strongerHuang】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
嵌入式開發(fā)入門指南:從零開始學(xué)習(xí)嵌入式
嵌入式開發(fā):高門檻的系統(tǒng)性工程與 996 的行業(yè)困局

BlackBerry QNX推出通用嵌入式開發(fā)平臺
AI來襲!嵌入式開發(fā)者該如何應(yīng)對轉(zhuǎn)型?

代碼+案例+生態(tài):武漢芯源半導(dǎo)體CW32嵌入式開發(fā)實(shí)戰(zhàn)正式出版

代碼+案例+生態(tài):武漢芯源半導(dǎo)體CW32嵌入式開發(fā)實(shí)戰(zhàn)正式出版
嵌入式開發(fā)必備-RK3562演示Linux常用系統(tǒng)查詢命令(上)觸覺智能出品

學(xué)嵌入式好找工作嗎?
新手怎么學(xué)嵌入式?
如何使用 RISC-V 進(jìn)行嵌入式開發(fā)
一文了解嵌入式軟件開發(fā)的對象

零基礎(chǔ)嵌入式開發(fā)學(xué)習(xí)路線
嵌入式開發(fā)常見問題排查

聚焦嵌入式開發(fā)中的合規(guī)性工具、項(xiàng)目管理工具、版本迭代工具應(yīng)用
嵌入式開發(fā)前景怎么樣?

評論