在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

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

3天內不再提示

談一談開發團隊代碼質量如何管控與提升

jf_ro2CN3Fa ? 來源:github ? 2023-07-16 15:39 ? 次閱讀

今天我們談一下開發團隊代碼質量如何做到管控與提升,我相信很多公司都會面臨這樣的問題,開發團隊大人員技術水平參差不齊,代碼寫的不夠規范,代碼掃描問題修改太過滯后,代碼庫管理每個團隊都不一致,偶爾還會合并丟失一些代碼,code review費人費時效率不高,開發任務的管理以及任務與代碼的可追溯問題,等等之類的問題,我們能否制定一套從設計到開發再到交付一整套的管控方案來幫助開發團隊管控代碼的質量?下來我就針對這些問題展開來談談我的想法。

舉個例子

比如說我們要增加代碼和任務之間的可追溯性,我們可能考慮采用git+jira關聯的方式對開發人員每筆提交在提交comment中增加jira編號,這是就是一個規范,但是規范落地如何檢查?開發人員如果忘記在comment中添加就會造成關聯失敗,那我們就要采用工具的方式幫助開發人員在提交時檢查comment是否符合規范。

比如說我們有制定編碼規范,也采用了sonar去掃描代碼的問題,但是這個方式的缺點是太過滯后,需要質量人員跟進去推動并且效果也不是很好,我們是否可以考慮前置檢查點幫助開發人員在代碼編寫和提交時能主動的發現問題,在代碼提交的時候發現規范問題可以直接進行解決再提交,我們可以考慮采用git加checkstyle、pmd、fingbug等工具插件,在代碼提交的時候進行規范檢測并且進行告警,這樣就可以很好的幫助開發人員及時的發現問題,并不是開發已經提交了再去sonar上檢查代碼規范來發現問題再事后的安排人員去解決,開發人員都有一個習慣,當功能開發好沒有問題后他們很少會去主動的修改與重構代碼,這樣就會導致遲遲不能推進,我們提前了檢查點幫助開發人員及時發現問題就可以更好的推行規范的落地。

因此我們要考慮提供一整套代碼質量管理的機制,應用在開發全生命周期中,并在關鍵的流程節點進行驗證,從而把控與提升代碼的質量。

基于 Spring Boot + MyBatis Plus + Vue & Element 實現的后臺管理系統 + 用戶小程序,支持 RBAC 動態權限、多租戶、數據權限、工作流、三方登錄、支付、短信、商城等功能

項目地址:https://github.com/YunaiV/ruoyi-vue-pro

視頻教程:https://doc.iocoder.cn/video/

常見的問題及我的看法

靜態代碼掃描太滯后,推進吃力

我相信大多都會使用類似sonar這類的靜態代碼檢查工具來檢查代碼,這里我們不說工具的好壞,我們只說檢查問題的修復情況,我相信很多開發都會有一種習慣,在代碼寫完之后如果上線沒有問題的話他們是很少會去主動的優化代碼,即使你掃描結果告訴他他也會有各種理由推脫,當然我們可以通過管理的手段強制他們修改,比如說blocker、critical級別的必須全部改掉,其余的看情況修改,當然通過管理手段從上往下會有一定的效果,但是這些都是比較滯后的方式,我們能不能提前發現問題讓開發在功能開發過程中就把發現的問題改掉?

這個當然是可以的,我們可以利用代碼檢查的機制,在代碼開發中就讓開發去掃描發現問題,在代碼提交的時候去校驗如果有嚴重的禁止代碼提交。這樣一來我們就可以提前來發現并解決問題,這樣可能會帶來的是開發人員的排斥,開發人員都覺得自己代碼寫的沒有問題,所以這塊我們需要把控這個檢查規則的寬松度,我們可以結合公司的開發規范,整理不同級別的問題,通過先簡后嚴的方式,先把開發的習慣培養起來后再逐漸的提升嚴格度,這樣一來開發就有個適應期也比較好接受,比如說:我們通過checkstyle的規則模板定義,前期把一些無用導入包、命名不規范、導入包用*、system.out語句這類接受度高的作為error級別來推動開發適應從而培養這種良好的習慣。

團隊Code Review沒有跑起來或跑的太費事費力

在技術行業做了一定時間的人應該都知道code review是多么的重要,一可以促進團隊人員之間互相交流,二可以提升整體團隊的技術水平,學習優秀人員寫的代碼,幫助初級人員提升代碼編寫能力,所以code review還是強烈必須要做的,至于怎么做code review?我談一下我的想法和建議

比較常見的方式是定期團隊內組織全體人員進行集中式的code review,我比較推薦利用工具在線的操作方式來做code review,現在開源非常的火也可以參考學習開源團隊code review的方式,比如說github有pull request,gitlab有merge request,可以在這個合并代碼的節點上進行code review,這樣做的好處是第一比較開放,只要能看到合并代碼請求的都可以進行review,第二可以留下review記錄,互相的想法溝通和建議可以很好的留存下來并且可以通過UI的方式友好的展示出來,從而提升code review效率。

這個當然需要結合git flow的機制來協作完成。

代碼庫分支、版本管理不規范,合并丟代碼

團隊多了或團隊大了,每個人或多或少對git的管理與使用理解不一致,這樣就造成了分支、版本管理的混亂,這樣在版本代碼合并時就會產生很多沖突,我們可以指定一套規范性的東西,指導開發團隊進行分支、版本的管理,這里說到的是指導不是限制,要讓開發在可控的范圍內自由發揮。

可以參考git flow、github flow等,當然我們要統一一個工作流程推廣給開發團隊中。

前面我們說了用代碼合并來進行code review,這樣我們就要讓開發人員在每開發完一個任務的時候就要進行一次代碼合并,git是一個優秀的分布式代碼庫管理工具,我們利用git的分布式特性,以及靈活的流程機制來規范大家的使用。

例如:

一次迭代沖刺或一個版本對應一個develop-*分支和release-*,并且控制分支的push與merge權限,固定一個master分支并且控制master分支的權限,讓個人開發通過feature-{username|功能名稱}-*分支來進行功能開發,當一個任務或者一個功能開發完成進行一次develop-*分支的合并,這樣一來及可以code review也可以有序的管理分支上的代碼,當開發人員提交合并請求時發生了沖突就需要開發人員自己解決完沖突后再進行代碼合并請求,這樣一來版本分支上代碼是有序的。

Name From Remark
master - 只能有一個并并且固定的
develop-* 從master創建 開發分支,可以結合jira的sprint,一個sprint對應一個,迭代開始時創建,’*’ 通常可以是一個發布周期或者一個沖刺命名
release-* 從master創建 預發布分支,可以結合jira的sprint,一個sprint對應一個,迭代開始時創建,’*’ 通常可以是一個發布周期或者一個沖刺命名
feature-{username or 功能名稱}-* 從develop-*創建 開發人員分支,這個分支的聲明周期很短,在這個功能開發完成通過Merge Request發起合并進行code review之后合并從而刪除分支

以上可以定位分支約定。

具體的操作可以參考下面描述:

sprint開始時(需求確認后),從master創建develop分支,例如是develop-V1.2.0

開發人員從對應的develop分支創建自己的feature分支進行開發

如果master分支發生變更,需要從master分支合并到對應的develop分支、可以考慮定期合并一次

feature分支合并到對應的develop之前,需要從develop分支合并到feature分支(這個避免和其他人提交進行沖突,規范開發人員自己解決掉沖突后才能發起合并請求)

feature分支合并到對應的develop之后,發布到測試環境進行測試(測試環境直接使用對應的develop分支)

develop分支在測試環境測試通過之后,合并到對應的release分支并發布到預發布環境(UAT)進行測試

release分支在預發布環境(UAT)驗證通過后,合并到master分支并發布到生產環境進行驗證

發布到生產環境后從master分支構建對應的版本tag

可同時支持多個sprint的并行。

代碼提交備注寫的很難懂甚至很隨意

代碼的提交備注非常重要,尤其是在合并代碼時產生沖突,第一時間肯定是根據提交日期去看本次提交做了什么修改,如果說備注隨便填寫,或者有些都沒有填這樣在回頭來看的時候,及時是提交本人他也不能第一時間看出具體做了哪些修改,因此我覺得作為一個開發人員提交備注寫的清晰明了是一件必備的職業素養,至于一些不按照規范的技術人員我們也可以要求他們按照規范必須填寫。

那如何做到對備注填寫的質量把控呢?我們可以通過版本管理工具在提交代碼時進行提交備注檢測,比如說對長度的限制,至少要15個字符,或者對格式做一些驗證,必須包含任務編號之類,這樣一來就可以有效的控制代碼提交備注的質量以及可讀性。

我們現在常用的git就有hook機制可以提供在代碼提交前后做一些鉤子,利用鉤子來控制允許提交或者拒絕提交,比如說git的pre-commit和commit-msg

開發人員的任務管理與提交代碼沒有關聯,無法查看某個任務具體提交了哪些代碼

優秀的開發人員主動性都是很好的,主動性對開發來說也是非常重要的職業素養,不要讓人催促你來完成任務,自己要學會主動找任務去做主動想如何優化與提升,所以時間任務管理是非常重要的,我任務開發人員都應該具備自己的時間任務管理能力,無論用什么工具只要能管理跟蹤好自己的任務就是不錯的人員。

公司一般都有任務管理工具,有的用禪道、有的用jira,現在用jira的相對多一些,jira的功能豐富也可以促進團隊進行敏捷的任務管理,我們可以通過打通任務管理工具和代碼版本工具,讓代碼提交的時候通過任務編號產生關聯,從而可以在任務中看到代碼修改的片段。

這里我用jira+git舉個例子,比如說我們利用jira做scrum的敏捷管理,在制定好epic、story、task、subtask后,可以通過scrum模型的管理手段,在開發過程中通過插件、圖標的數據來分析是否有風險?那個人的任務delay?那個人的任務制定還可以再進行拆分?等,從而盡早的做出調整來控制整個迭代周期按時完成。利用git提交的備注寫入jira編號,通過jira和git的插件打通任務與提交代碼的關聯,這樣一來我們就可以很好的看到任務執行過程數據與具體改動了哪些代碼,從而提升開發效率。

統一管理校驗規則版本,由簡到嚴循序漸進的方式提升代碼質量

我們上面說到的利用了checkstyle來驗證代碼風格,通過git hook來控制提交備注的規范,這些都需要自定義一些腳本,這些腳本也應該利用git進行有效的管理,我們能力能做到統一的調整了規則與腳本,開發過程中的應用立即使用最新的驗證規則?還有git hooks的腳本是在開發機器本地運行的,這樣就帶來了一個問題如何讓開發去安裝腳本呢?叫他們手動安裝?寫個bat或shell腳本讓開發執行一次?

我覺得更好的方式是對開發透明在他們不知覺的時候已經悄悄的安裝,我們可以利用git對規則與腳本的版本進行管理,利用nginx可以通過http方式直接訪問規則與腳本文件,通過自定義maven plugin在代碼build的時候驗證開發機器上是否已經安裝,如果沒有就給它自動安裝與自動更新。

這樣我們只要修改了規則與腳本后進行版本發布,開發機就會自動的更新下來從而可以立即生效。

開發團隊技術氛圍低沉

很多公司開發團隊一味的滿頭苦干,很容易忽視團隊內的技術分享,再加上團隊內人員進進出出有一些正能量的人當然也有一些負能量的人,這都是常事,但是不管怎樣我相信做技術的人都愿意提升自己的技術能力,不管是工作中實踐學習還是說參加沙龍或者論壇,都是很好的學習渠道,人的精力也是比較有限不可能關注很多面,通過團隊內的技術分享,把每個人擅長的部分分享給大家,互相學習來提升凝聚力和團隊整體的技術水平,這樣長期以來我相信團隊內的技術氛圍肯定不會差。

基于 Spring Cloud Alibaba + Gateway + Nacos + RocketMQ + Vue & Element 實現的后臺管理系統 + 用戶小程序,支持 RBAC 動態權限、多租戶、數據權限、工作流、三方登錄、支付、短信、商城等功能

項目地址:https://github.com/YunaiV/yudao-cloud

視頻教程:https://doc.iocoder.cn/video/

總結

以上就是我對代碼質量管理與提升方面的經驗與思考,里面涉及到很多東西,有流程的制定、工具的協作、工具的打通、規范的制定等,因此這是一個系統性的方案,希望可以利用一整套代碼質量管理的流程,在關鍵的流程節點來把控代碼的質量,形成閉環,希望可以幫助有需要的人,如果有更好的建議也希望大家多提意見進行補充,沒有完美的方式,只有找到適合的可落地的就是好的。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 編碼
    +關注

    關注

    6

    文章

    946

    瀏覽量

    54869
  • 代碼
    +關注

    關注

    30

    文章

    4798

    瀏覽量

    68728

原文標題:談一談開發團隊代碼質量如何管控與提升

文章出處:【微信號:芋道源碼,微信公眾號:芋道源碼】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    談開關電源PCB設計

    對于開關電源的研發,PCB設計占據很重要的地位。個差的PCB,EMC性能差、輸出噪聲大、抗干擾能力弱,甚至連基本功能都有缺陷。與其他硬件電路PCB稍有不同,開關電源PCB有些自身的特點。本文將結合工程經驗,簡單談一談開關電源
    發表于 11-16 14:35 ?3089次閱讀

    提升視頻質量的軟件

    Video Enhancer 是提升視頻質量的軟件。采用大量的VirtualDub濾鏡和附加的編碼器重新壓縮的視頻處理,將馬賽克進行還原。
    發表于 05-27 13:35

    提升團隊編碼效率的10個提示

    與其他活動類似,Web或軟件開發也是個社會性活動,如果你是個開發者或設計師,那很有可能你會身處在團隊之中。團隊由不同的人構成,每個人都有
    發表于 12-11 14:34

    嵌入式代碼質量開發效率技術沙龍

    %,預計未來還會增長。隨著嵌入式/物聯網領域的軟件復雜度不斷提高,如何在不斷變化的需求中保證開發效率,確保代碼質量顯得尤其的重要。不少開發者都有過這樣的經歷:
    發表于 03-19 18:32

    談一談嵌入式開發怎么入門的

    想要從事嵌入式開發,但又不知道怎么入門的,可以看下,下面我結合自身實際來談一談。前提基礎:簡單的電路、模電、數電知識,C語言、從51單片機入手如果有些前提的基礎知識,要上手51單片
    發表于 12-17 08:12

    代碼質量和其整潔度成正比有什么道理如何進行代碼整潔教材免費下載

    。軟件質量,不但依賴于架構及項目管理,而且與代碼質量緊密相關。這點,無論是敏捷開發流派還是傳統開發
    發表于 11-28 08:00 ?1次下載

    代碼平臺如何平衡開發速度和質量

    代碼平臺的出現幫助企業提高了軟件開發的速度,速度提高之后很多人都會問那么軟件的質量是不是會受到影響呢?低代碼平臺如何平衡開發速度和
    發表于 05-13 16:36 ?580次閱讀

    談開關電源的指標及檢測

    談開關電源的指標及檢測(現代高頻開關電源技術及應用)-談開關電源的指標及檢測下載,需要的自行下載!
    發表于 09-29 15:11 ?15次下載
    <b class='flag-5'>談開</b>關電源的指標及檢測

    什么是HarmonyOS低代碼開發

    什么是低代碼開發?低代碼開發主要特點有哪些?如何利用低代碼開發原子化服務?本文帶你
    的頭像 發表于 11-22 10:50 ?2307次閱讀

    幾種檢查代碼質量的利器介紹

    、SonarLint,讓你在關注代碼質量的同時,減少 code review 的工作量,提高 code review 的效率,并通過代碼質量分析去反向
    的頭像 發表于 11-02 11:04 ?1358次閱讀

    談一談PCB翹曲度的標準以及如何測量

    談一談PCB翹曲度的標準以及如何測量
    的頭像 發表于 11-27 17:28 ?5321次閱讀
    <b class='flag-5'>談一談</b>PCB翹曲度的標準以及如何測量

    如何提升代碼質量與效率的秘訣

    提高編程能力其實沒有捷徑,最佳方式就是多寫代碼。 不過,除了寫大量代碼提升編程能力還需要大量閱讀別人寫的代碼
    的頭像 發表于 04-28 14:53 ?407次閱讀
    如何<b class='flag-5'>提升</b><b class='flag-5'>代碼</b><b class='flag-5'>質量</b>與效率的秘訣

    三星電子組建HBM4團隊,旨在縮短開發周期,提升競爭力

    據此,現有的DRAM設計團隊將主要負責HBM3E內存的開發和優化,而今年三月份新設立的HBM產能與質量提升團隊則專攻下
    的頭像 發表于 05-11 18:01 ?1496次閱讀

    艾體寶產品 CircleCI:高效的CI/CD平臺,助力開發團隊加速交付!

    集成,提升團隊協作與代碼質量。本文詳細介紹了CircleCI的主要功能和實際應用場景,幫助團隊更高效地實現持續集成與交付。
    的頭像 發表于 11-20 10:22 ?214次閱讀
    艾體寶產品 CircleCI:高效的CI/CD平臺,助力<b class='flag-5'>開發</b><b class='flag-5'>團隊</b>加速交付!

    Jenkins 與 SonarQube 集成部署,自動化代碼質量監控

    的性能表現,為 Jenkins 與 SonarQube 的集成部署提供強大支撐。在 Flexus X 的助力下,自動化代碼掃描與質量問題即時反饋成為可能,顯著提升團隊
    的頭像 發表于 01-07 17:24 ?113次閱讀
    Jenkins 與 SonarQube 集成部署,自動化<b class='flag-5'>代碼</b><b class='flag-5'>質量</b>監控
    主站蜘蛛池模板: 天天碰夜夜| 久久夜靖品| 在线播放免费人成毛片乱码| 奇米奇米| 国产精品视频久久久久久| 午夜影院18| 国产五月婷婷| 女人张开腿男人桶| 毛片特黄| 成人伊人青草久久综合网| 六月婷婷导航福利在线| 色婷婷亚洲十月十月色天| 男人的亚洲天堂| a中文字幕1区| 我要看18毛片| 日本最色视频| 色多多网站在线观看| 日本黄色免费片| 日韩一级免费视频| 毛片a区| bt种子在线www天堂官网| 国产caob| 国产一线在线观看| 中文天堂网| 永久在线| 8050网午夜一级毛片免费不卡 | 高清欧美性xxxx成熟| 999久久久国产精品| 国产精品午夜在线观看| 啪啪网免费| 国产精品污视频| 色在线免费观看| 狠狠狠色丁香婷婷综合激情| 黄色一级片网址| 午夜在线视频免费| 天天草视频| 奇米影视777四色米奇影院| 亚洲乱强| 一区二区三区伦理| 亚洲成人77777| 免费番茄社区性色大片|