新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 業(yè)界動態(tài) > 短視思維會帶來什么?技術(shù)債務(wù)舉手“發(fā)言”

短視思維會帶來什么?技術(shù)債務(wù)舉手“發(fā)言”

作者:Paul Gillin 演說家、作家和B2B內(nèi)容營銷策略師,TechTarget的創(chuàng)始總編輯,曾擔(dān)任《計算機(jī)世界》雜志的總編輯兼執(zhí)行編輯長達(dá)12年。 時間:2022-06-27 來源:電子產(chǎn)品世界 收藏

大多數(shù)軟件開發(fā)人員都很熟悉,而編程專業(yè)以外的人就不一定知道了。但了解這個概念十分重要,因為它不僅存在于編程領(lǐng)域,也存在于短期決策可能影響長期結(jié)果的廣泛場景。

本文引用地址:http://butianyuan.cn/article/202206/435575.htm

什么是?

簡而言之,當(dāng)軟件開發(fā)團(tuán)隊急于快速交付而忽略了代碼質(zhì)量時,就會產(chǎn)生,比如用戶可能迫切需要某項功能,所以開發(fā)人員選擇先部署“僅僅夠用”的代碼并打算在以后再修復(fù)和優(yōu)化。如果最后沒有重新檢查和修復(fù)這段代碼,這圖一時方便的操作所帶來的代價就是日后工作量的增加,就像不償還貸款就會產(chǎn)生利息和罰金一樣。技術(shù)債務(wù)本身不一定是問題,但如果日后產(chǎn)品優(yōu)化不足或者任由異常的代碼泛濫,就會成為一個不容小覷的問題。為了跟上市場快速變化的步伐,企業(yè)轉(zhuǎn)向的敏捷開發(fā)在一定程度上加劇了技術(shù)債務(wù)的風(fēng)險,開發(fā)運維(DevOps)促進(jìn)頻繁的代碼發(fā)布和持續(xù)不斷的改進(jìn),每天甚至每幾個小時就需要推送新代碼,開發(fā)人員可能會迫于壓力而在文檔規(guī)則或測試上“走捷徑”。

技術(shù)債務(wù)實例

“計算機(jī)千年蟲危機(jī)”正是一個經(jīng)典的技術(shù)債務(wù)案例。在六十年代和七十年代,許多軟件開發(fā)人員為了節(jié)省寶貴的內(nèi)存而只使用兩位十進(jìn)制數(shù)來表示年份,比如“1973年”被存儲為“73”而不是“1973”。這種做法持續(xù)了多年,甚至在內(nèi)存價格下降的時候也是如此。許多這樣的程序被嵌入到運營業(yè)務(wù)中,并且使用的時間遠(yuǎn)遠(yuǎn)超過了人們的預(yù)期。隨著2000年的臨近,數(shù)千家企業(yè)和政府機(jī)構(gòu)意識到當(dāng)系統(tǒng)進(jìn)行跨世紀(jì)的日期處理運算時就會出現(xiàn)錯誤的結(jié)果,進(jìn)而引發(fā)各種各樣的系統(tǒng)功能紊亂甚至崩潰,因此進(jìn)行了大量瘋狂的清理工作。據(jù)估計,解決“千年蟲問題”花費了近千億美元。

另外,技術(shù)債務(wù)并不止發(fā)生在軟件上。比如網(wǎng)絡(luò)安全領(lǐng)域的一項最佳實踐是將文件權(quán)限授予組織內(nèi)的角色而不是個人。假設(shè)一名行政助理得到了上級的批準(zhǔn),可以臨時訪問他平時無權(quán)查看的敏感文件。如果IT組織批準(zhǔn)了這一例外,但在后來沒有撤銷權(quán)限,那就等同于把敏感文件的永久訪問權(quán)授予了一個最終可能被入侵并出現(xiàn)漏洞的帳戶。

技術(shù)債務(wù)的影響

如果短期內(nèi)能夠迅速修復(fù)并且開發(fā)人員知道如何處理技術(shù)債務(wù),那么技術(shù)債務(wù)幾乎不會產(chǎn)生壞處,甚至促使企業(yè)快速響應(yīng)機(jī)會或問題而帶來好處。

但當(dāng)技術(shù)債務(wù)層層疊加時,修復(fù)工作因為缺少文檔記錄或者根本沒有文檔記錄,且當(dāng)執(zhí)行修復(fù)工作的開發(fā)人員離職后,企業(yè)對這段代碼只能束手無策,不知其義何談修復(fù)。任何冒然的更改都可能會導(dǎo)致程序失敗或運行緩慢,企業(yè)怕承擔(dān)該風(fēng)險就不愿做出改進(jìn),使得創(chuàng)新速度減慢。

技術(shù)債務(wù)的類型

技術(shù)債務(wù)主要分為有意產(chǎn)生和無意產(chǎn)生。開發(fā)人員培訓(xùn)公司Construx的首席執(zhí)行官Steve McConnell將有意產(chǎn)生的技術(shù)債務(wù)定義為根據(jù)戰(zhàn)略故意承擔(dān)的技術(shù)債務(wù),將無意產(chǎn)生的技術(shù)債務(wù)定義為“因為做得不好而產(chǎn)生的非戰(zhàn)略結(jié)果”。

2014年,一群學(xué)者制定了技術(shù)債務(wù)分類法,將技術(shù)債務(wù)分成13種不同的類型,包括架構(gòu)債務(wù)、代碼債務(wù)、缺陷債務(wù)、設(shè)計債務(wù)、流程債務(wù)和測試債務(wù)等。這種分類法涵蓋了所有因短視思維而可能導(dǎo)致的長期問題的場景,因此十分實用。

技術(shù)債務(wù)的產(chǎn)生

有意產(chǎn)生的技術(shù)債務(wù)是刻意做出的決定,因此應(yīng)記錄成文檔并安排重構(gòu)。而無意產(chǎn)生的技術(shù)債務(wù)發(fā)生的原因可能是臨時措施產(chǎn)生了修改或添加并且沒有特意制定代碼重構(gòu)計劃,也可能是由于缺乏技術(shù)知識或未能遵守開發(fā)標(biāo)準(zhǔn)而導(dǎo)致的不良設(shè)計決策。例如,當(dāng)測試套件不完整或者為了方便而縮短或跳過測試環(huán)節(jié)時,就會無意產(chǎn)生測試債務(wù)。

文檔債務(wù)是一種十分常見的技術(shù)債務(wù),發(fā)生的原因是開發(fā)人員沒有完整記錄他們的代碼。從長遠(yuǎn)看,如果有人在離開公司時沒有留下幫助別人理解其代碼的線索,就會產(chǎn)生嚴(yán)重的問題。文檔債務(wù)是造成“千年蟲問題”的一個主要原因。

技術(shù)債務(wù)的預(yù)兆

技術(shù)債務(wù)的“預(yù)警信號”有:

●   由于開發(fā)人員缺乏對代碼庫的深入了解而導(dǎo)致項目陷入困境;

●   由于復(fù)雜性或缺乏文檔而出現(xiàn)難以修復(fù)的錯誤;

●   錯誤修復(fù)后產(chǎn)生了新的錯誤或性能穩(wěn)定下降。

技術(shù)債務(wù)的預(yù)防

要知道如何處理技術(shù)債務(wù),首先要有健全的開發(fā)實踐,比如DevOps環(huán)境中的測試左移和右移。測試左移是指將測試流程提前到整個開發(fā)周期中,以便在生產(chǎn)之前預(yù)見并解決問題。測試右移是指在應(yīng)用進(jìn)入生產(chǎn)階段后收集反饋,以便在軟件被廣泛使用之前提前發(fā)現(xiàn)并修復(fù)錯誤。這些預(yù)防措施可以防止產(chǎn)生更大的問題。

造成技術(shù)債務(wù)的臨時措施不可避免,但開發(fā)人員必須記錄在案,包括原因和修復(fù)說明。也可以通過定期審查現(xiàn)有代碼,讓團(tuán)隊成員互相檢查工作,主動發(fā)現(xiàn)文檔的缺陷或異常代碼。

了解技術(shù)債務(wù)的重要性

有人說現(xiàn)在每家公司都是軟件公司,每年構(gòu)建的軟件數(shù)量持續(xù)快速增長。就連重工業(yè)企業(yè)也在為了讓客戶從購買的產(chǎn)品中獲得更多價值而挖掘數(shù)據(jù)。

與此同時,開發(fā)部門需要將項目快速投產(chǎn),忙碌不堪的開發(fā)人員自然會“走捷徑”,而項目經(jīng)理應(yīng)該予以理解并向團(tuán)隊強調(diào)測試和文檔記錄的重要性。

有哪些最佳實踐?

采用DevOps技術(shù)的企業(yè)應(yīng)該明確什么是技術(shù)債務(wù)并采取敏捷的策略加以管理。企業(yè)可以使用測試右移和左移以及A/B和金絲雀測試技術(shù)在問題失控之前發(fā)現(xiàn)問題;另外,同行代碼審查能夠從新的視角檢查開發(fā)人員的工作。開發(fā)人員應(yīng)該使用一套統(tǒng)一的規(guī)定工具和語言,并有一份每個階段需要完成的任務(wù)清單。有效率的DevOps部門不但提供開發(fā)人員足夠的自由度以構(gòu)建應(yīng)用,同時制定軟件開發(fā)規(guī)范以確保開發(fā)質(zhì)量。

—減輕技術(shù)債務(wù)的好工具

為了更加有效地減輕技術(shù)債務(wù),企業(yè)可以在每次變更模塊時使用自動化測試對每項代碼的改動進(jìn)行多輪調(diào)試;通過建立強制文檔化等健全的代碼結(jié)構(gòu)流程;將程序員安排成兩人一組,使他們可以了解彼此的決策;使用項目管理工具可視化團(tuán)隊中每個人的工作狀態(tài)等。

此外,使用低代碼和無代碼工具編寫的軟件日益增加。由于流程圖和拖放技術(shù)能以可視化的方式呈現(xiàn)邏輯和預(yù)期結(jié)果,因此這些軟件很大程度上實現(xiàn)了自動歸檔。此外,所生成的代碼可以按原計劃運行,也可以出于自定義或性能目的進(jìn)行修改,開發(fā)經(jīng)理應(yīng)該鼓勵團(tuán)隊使用低代碼和無代碼技術(shù),以提高生產(chǎn)效率。



評論


技術(shù)專區(qū)

關(guān)閉