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

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

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

編程的三大經(jīng)驗方法總結(jié)

m3eY_edn_china ? 2018-03-05 10:20 ? 次閱讀

今年將迎來我編程的第十七個年頭。我的編程之旅始于九十年代末,上大學(xué)的時候,主要涉足基于表格的網(wǎng)頁設(shè)計,傳統(tǒng)的ASP,和Microsoft Access數(shù)據(jù)庫。原來只是當作業(yè)余愛好的編程現(xiàn)在已經(jīng)成為了我的事業(yè)和激情。我一生一半的時間都在學(xué)習(xí)、蹣跚、成功、失敗,并且經(jīng)常情不自禁地為代碼美麗和復(fù)雜的天性而折腰。

我在代碼上淫浸了足夠長的時間,因此看到了很多語言和平臺的興盛和消亡,看到了很多模式被普及,被苛責(zé),然后再次被推廣。在某些時候,我常常分不清這是大勢所趨還是明日黃花。

編程的流行趨勢是短暫的,但我堅守的規(guī)則,往往在生活中的其他地方也能發(fā)揮作用。事實上,生活就像代碼(我已經(jīng)買了這個域名來證明這一點?。R韵率俏铱偨Y(jié)的3個偉大的經(jīng)驗教訓(xùn),歷經(jīng)一次又一次編程和生活的大浪淘沙。

1.可商榷的決定往往是一種權(quán)衡。

偉大的辯論總是發(fā)生在開發(fā)社區(qū)中。無論它是最近關(guān)于TDD作為web開發(fā)的一種可行方法的辯論,還是什么水平的開發(fā)人員應(yīng)該使用ORM(或micro-ORMs)。無論是.NET MVC應(yīng)該優(yōu)于WebForms還是以JavaScript為中心的app應(yīng)該比基于頁面的app更受青睞,對我來說,答案都一樣:看你權(quán)衡之后的取舍?

在任何比較兩種流行方法的辯論中,我們總是會從自己的立場出發(fā),兩利相權(quán)取其重,兩害相權(quán)取其輕。在我的職業(yè)生涯早期,我曾執(zhí)著于追求所謂的正確答案。感覺過程是線性的:擺脫做事的老辦法,轉(zhuǎn)而投向新的并且更好的方法的懷抱。曾經(jīng)有一段時間我深信,編寫自己的SQL查詢是一種過時的練習(xí),并且ORMs是最后贏家。

但是,我了解到,更好的辦法應(yīng)該由內(nèi)容決定的。例如,今天完全成熟的ORMs在隔離映射相關(guān)數(shù)據(jù)網(wǎng)格到對象的冗長管道提供了偉大服務(wù),但隔離也使得某種非標準查詢變得困難并且有潛在的效率低下問題。n+1 select problem就是經(jīng)典的在少寫代碼和寫更多高效代碼之間做權(quán)衡。我使用ORM的程度完全受我期待應(yīng)用程序使用的數(shù)據(jù)量,我所受到的潛在的時間限制,app長期可擴展性需求這三者的影響。(順便說一句,我目前是micro-ORMs,比如說Dapper的忠實粉絲,它能讓我編寫我自己的SQL和一些精巧的對象-關(guān)系映射)。

我已經(jīng)將這個經(jīng)驗應(yīng)用到了我生活的其他方面。我是應(yīng)該買一套公寓還是長租房子?我是應(yīng)該啟動自己的生意還是工作于已經(jīng)成立的公司?沒有絕對正確的選擇。當你權(quán)衡利弊了之后,你便可以更好地應(yīng)對生活中的各種難題。

2.清晰并不總和簡潔相關(guān)。

和大多數(shù)工程師一樣,我對持續(xù)重構(gòu)一直到代碼盡可能地少和簡潔的機會垂涎三尺。如果可以選擇更少又更簡潔的代碼來完成同樣的任務(wù),那么我為什么要選擇要個更多代碼的方案呢?通常情況下,更簡潔的語言會導(dǎo)致更好的交流。畫蛇添足只會阻礙核心信息的提取。但是,最終的目標不應(yīng)該是簡潔——而應(yīng)該是可交流。于我而言,下面這段直截了當?shù)拇a,在它更長的時候……

if (HasFarm() && HasBoat()) { Broadcast("You are wealthy!"); } else if (HasFarm() && !HasBoat()) { Broadcast("You are OK!"); } else if (!HasFarm() && HasBoat()) { Broadcast("You are OK!"); } else if (!HasFarm() && !HasBoat()) { Broadcast("You are poor!"); }

……反而比這個簡潔版本更明確。

(HasFarm() && HasBoat()) ? Broadcast("You are wealthy!") : (HasFarm() || HasBoat()) ? Broadcast("You are OK!") : Broadcast("You are poor!");

雖然這是一個品味問題(有些人可能會覺得后者看上去更加一目了然),但是我在這里要表述的觀點是,有時候解釋的最偉大方法并不是簡化。這個經(jīng)驗也適用于日常生活,我花了大量時間來思考怎么樣才能更好地傳達消息以便于對方接收——有時更詳細的講解并非沒有價值,而是更明確傳達信息的必須。

舉例來說,我想要更明確和更詳細地告訴我爸爸應(yīng)該如何關(guān)閉iPad(“按住右側(cè)的按鈕一段時間……”)?;蛘?,我看似多此一舉地鍵入了一些我已經(jīng)提交到本地分支的內(nèi)容給我的同事(“剛剛犯的錯誤已被修復(fù)”),然后當它涉及到部署更新到產(chǎn)品中時,我就能很明確地知道哪些具體的提交被合并和出現(xiàn)(“檢查4812-4822行,其中包括在6/15發(fā)行版本中的DoneDone問題,將在今晚的產(chǎn)品發(fā)布中提出來。”)。

3.累計良性債務(wù),并且要持續(xù)償還。

我在一個特別害怕欠債的家庭中長大。八十年代中期,我的父母傾其所有又東拼西湊,付了他們第一套房子75%的首付,然后在七年內(nèi)付清了剩余款項。用現(xiàn)金支付是常態(tài)。信用支付在他們看來幾乎是一種罪過。作為一個孩子,我的看法是,債務(wù)完全是壞的。我從不認為欠債是一種優(yōu)勢。

直到我看到其他人是如何對待債務(wù)的——在我20出頭的時候——我終于知道了債務(wù)也可以是有益的。如果你能夠合理地承擔(dān)債務(wù),那么之后你也能獲得成功。如果借助現(xiàn)在更好的上升空間可以加速你之后的成長,那么債務(wù)可以成為一筆巨大的財富。

代碼也是如此。有時它值得你現(xiàn)在承擔(dān)一點債務(wù)——錯過抽象或者有一些未優(yōu)化的SQL代碼——如果這樣做可以讓你更快地發(fā)布內(nèi)容給不斷增長的觀眾的話。關(guān)鍵是要了解你必須償還它,以及你可以在適當?shù)臅r間段之后償還。

這就是債務(wù)在生活和編程中的竅門。償還債務(wù)需要持續(xù)進行。將一周10%的時間用于重構(gòu),相當于你是在按時支付編碼的信用卡賬單。如果你保持一種持續(xù)、可支撐的還債狀態(tài),那么累積債務(wù)實際上對你是有好處的。

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

    關(guān)注

    88

    文章

    3544

    瀏覽量

    93470

原文標題:17年編程生涯的三大經(jīng)驗總結(jié)

文章出處:【微信號:edn-china,微信公眾號:EDN電子技術(shù)設(shè)計】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    單片機設(shè)計與KeilC編程總結(jié)

    本內(nèi)容總結(jié)了一些單片機設(shè)計與KeilC編程經(jīng)驗規(guī)則來方面大家學(xué)習(xí)
    發(fā)表于 12-14 10:41 ?5529次閱讀

    單片機軟件編程的五大經(jīng)驗

    經(jīng)驗之一:用“軟件陷阱+程序口令”對付PC指針的彈飛經(jīng)驗之二、不要輕信軟件狗經(jīng)驗、話說RAM冗余技術(shù)經(jīng)驗之四、話說指令冗余技術(shù)
    發(fā)表于 07-30 22:21

    電力設(shè)備高壓試驗方法有哪些?

    華天電力專業(yè)生產(chǎn)串聯(lián)諧振裝置,可進行各種高壓試驗。電力設(shè)備高壓試驗的方法有哪些?高壓試驗是檢測電力設(shè)備能否正常運行的一種常見且有效的手段,試驗方法當然也有很多,華天電力為您整理總結(jié)主要的
    發(fā)表于 11-01 10:11

    3種保護LED電路方法經(jīng)驗總結(jié)

    3種保護LED電路方法經(jīng)驗總結(jié) 1.保護LED電路中采用保險絲(管) 由于保險絲是一次性的,且反應(yīng)速度
    發(fā)表于 11-14 09:57 ?650次閱讀

    線圈天線設(shè)計經(jīng)驗總結(jié)

    線圈天線設(shè)計經(jīng)驗總結(jié)
    發(fā)表于 09-12 17:21 ?224次下載

    PCB布線經(jīng)驗(九大經(jīng)典文檔)

    PCB布線經(jīng)驗(九大經(jīng)典文檔),PCB布線經(jīng)驗(九大經(jīng)典文檔)。
    發(fā)表于 12-25 09:54 ?0次下載

    PCB布線經(jīng)驗技巧總結(jié)

    PCB布線經(jīng)驗技巧總結(jié),好東西,喜歡的朋友可以下載來學(xué)習(xí)。
    發(fā)表于 01-20 15:20 ?0次下載

    我和LabVIEW 一個NI工程師的十年編程經(jīng)驗(PDF及實例程

    《我和LabVIEW:一個NI工程師的十年編程經(jīng)驗》是作者在學(xué)習(xí)和使用LabVIEW過程中的經(jīng)驗總結(jié)。書中由淺入深地對LabVIEW最常用的功能和LabVIEW學(xué)習(xí)過程中常見的問題進行了一一
    發(fā)表于 05-06 11:47 ?0次下載

    基于verilog的FPGA編程經(jīng)驗總結(jié)

    用了半個多月的ISE,幾乎全是自學(xué)起來的,碰到了很多很多讓人DT好久的小問題,百度也百不到,后來還是都解決了,為了盡量方便以后的剛學(xué)ISE的童鞋不再因為一些小問題而糾結(jié),把這幾天的經(jīng)驗總結(jié)了一下。好了,廢話不多說,上料!
    發(fā)表于 02-11 11:22 ?1446次閱讀
    基于verilog的FPGA<b class='flag-5'>編程</b><b class='flag-5'>經(jīng)驗總結(jié)</b>

    指針經(jīng)驗總結(jié)

    指針經(jīng)驗總結(jié)
    發(fā)表于 10-27 15:44 ?19次下載
    指針<b class='flag-5'>經(jīng)驗總結(jié)</b>

    深度解讀PLC的編程實例及經(jīng)驗方法總結(jié)

    PLC控制系統(tǒng)的輸入信號和輸出負載:繼電器電路圖中的交流接觸器和電磁閥等執(zhí)行機構(gòu)用PLC的輸出繼電器來控制,它們的線圈接在PLC的輸出端。
    的頭像 發(fā)表于 11-24 15:39 ?1.5w次閱讀
    深度解讀PLC的<b class='flag-5'>編程</b>實例及<b class='flag-5'>經(jīng)驗方法</b><b class='flag-5'>總結(jié)</b>

    機器學(xué)習(xí)的12大經(jīng)驗總結(jié)

    本文整理了關(guān)于機器學(xué)習(xí)研究者和從業(yè)者的 12 個寶貴經(jīng)驗,包括需要避免的陷阱、需要關(guān)注的重點問題、常見問題的答案。希望這些經(jīng)驗對機器學(xué)習(xí)愛好者有一些幫助。
    的頭像 發(fā)表于 12-13 15:29 ?2634次閱讀

    學(xué)習(xí)plc編程經(jīng)驗總結(jié)

    我們以最熟悉的可編程控制器來說說如何進行理論學(xué)習(xí)和實踐操作。我認為學(xué)習(xí)編程軟件最重要的是理論和實踐相結(jié)合,特別是編程軟件很難通過只學(xué)理論就學(xué)會的,必須輔助大量的實踐,按時間上的分配來說應(yīng)該是
    的頭像 發(fā)表于 10-19 09:25 ?4154次閱讀

    常用的種PLC編程方法

    常用的PLC編程方法經(jīng)驗法、解析法、圖解法。
    發(fā)表于 05-03 17:45 ?6898次閱讀

    EMI整改經(jīng)驗總結(jié)

    EMI整改經(jīng)驗總結(jié)
    發(fā)表于 12-20 15:55 ?45次下載