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

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

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

3天內不再提示

采用這六個 Git 協作策略,讓嵌入式團隊工作更高效

如意 ? 來源:Linux中國 ? 作者:Ravi Chandran ? 2020-09-17 11:46 ? 次閱讀

采用這些 Git 協作策略,讓團隊工作更高效。

Git 非常有助于小團隊管理他們的軟件開發進度,但有些方法能讓你變得更高效。我發現了許多有助于我的團隊的最佳實踐,尤其是當不同 Git 水平的新人加入時。

在你的團隊中正式確立 Git 約定

每個人都應當遵循對于分支命名、標記和編碼的規范。每個組織都有自己的規范或者最佳實踐,并且很多建議都可以從網上免費獲取,而重要的是盡早選擇合適的規范并在團隊中遵循。

同時,不同的團隊成員的 Git 水平參差不齊。你需要創建并維護一組符合團隊規范的基礎指令,用于執行通用的 Git 操作。

正確地合并變更

每個團隊成員都需要在一個單獨的功能分支上開發。但即使是使用了單獨的分支,每個人也會修改一些共同的文件。當把更改合并回 master 分支時,合并通常無法自動進行??赡苄枰謩咏鉀Q不同的人對同一文件不同變更的沖突。這就是你必須學會如何處理 Git 合并的原因。

現代編輯器具有協助解決 Git 合并沖突的功能。它們對同一文件的每個部分提供了合并的各種選擇,例如,是否保留你的更改,或者是保留另一分支的更改,亦或者是全部保留。如果你的編輯器不支持這些功能,那么可能是時候換一個代碼編輯器了。

經常變基你的功能分支

當你持續地開發你的功能分支時,請經常對它做變基rebase:rebase master。這意味著要經常執行以下步驟:

采用這六個 Git 協作策略,讓嵌入式團隊工作更高效

這些步驟會在你的功能分支上重寫歷史(這并不是件壞事)。首先,它會使你的功能分支獲得 master 分支上當前的所有更新。其次,你在功能分支上的所有提交都會在該分支歷史的頂部重寫,因此它們會順序地出現在日志中。你可能需要一路解決遇到的合并沖突,這也許是個挑戰。但是,這是解決沖突最好的時機,因為它只影響你的功能分支。

在解決完所有沖突并進行回歸測試后,如果你準備好將功能分支合并回 master,那么就可以在再次執行上述的變基步驟幾次后進行合并:

采用這六個 Git 協作策略,讓嵌入式團隊工作更高效

在此期間,如果其他人也將和你有沖突的更改推送到 master,那么 Git 合并將再次發生沖突。你需要解決它們并重新進行回歸測試。

還有一些其他的合并哲學(例如,只使用合并而不使用變基以防止重寫歷史),其中一些甚至可能更簡單易用。但是,我發現上述方法是一個干凈可靠的策略。提交歷史日志將以有意義的功能序列進行排列。

如果使用“純合并”策略(上面所說的,不進行定期的變基),那么 master 分支的歷史將穿插著所有同時開發的功能的提交。這樣混亂的歷史很難回顧。確切的提交時間通常并不是那么重要。最好是有一個易于查看的歷史日志。

在合并前壓扁提交

當你在功能分支上開發時,即使再小的修改也可以作為一個提交。但是,如果每個功能分支都要產生五十個提交,那么隨著不斷地增添新功能,master 分支的提交數終將無謂地膨脹。通常來說,每個功能分支只應該往 master 中增加一個或幾個提交。為此,你需要將多個提交壓扁Squash成一個或者幾個帶有更詳細信息的提交中。通常使用以下命令來完成:

git rebase -i HEAD~20 # 查看可進行壓扁的二十個提交

當這條命令執行后,將彈出一個提交列表的編輯器,你可以通過包括遴選pick或壓扁squash在內的數種方式編輯它?!板噙x”一個提交即保留這個提交?!皦罕狻币粋€提交則是將這個提交合并到前一個之中。使用這些方法,你就可以將多個提交合并到一個提交之中,對其進行編輯和清理。這也是一個清理不重要的提交信息的機會(例如,帶錯字的提交)。

總之,保留所有與提交相關的操作,但在合并到 master 分支前,合并并編輯相關信息以明確意圖。注意,不要在變基的過程中不小心刪掉提交。

在執行完諸如變基之類的操作后,我會再次看看 git log 并做最終的修改:

git commit --amend

最后,由于重寫了分支的 Git 提交歷史,必須強制更新遠程分支:

git push -f

使用標簽

當你完成測試并準備從 master 分支部署軟件到線上時,又或者當你出于某種原因想要保留當前狀態作為一個里程碑時,那么可以創建一個 Git 標簽。對于一個積累了一些變更和相應提交的分支而言,標簽就是該分支在那一時刻的快照。一個標簽可以看作是沒有歷史記錄的分支,也可以看作是直接指向標簽創建前那個提交的命名指針。

所謂的“配置控制”就是在不同的里程碑上保存代碼的狀態。大多數項目都有一個需求,能夠重現任一里程碑上的軟件源碼,以便在需要時重新構建。Git 標簽為每個代碼的里程碑提供了一個唯一標識。打標簽非常簡單:

采用這六個 Git 協作策略,讓嵌入式團隊工作更高效

考慮這樣一種情況:Git 標簽對應的軟件版本已經分發給客戶,而客戶報告了一個問題。盡管代碼庫中的代碼可能已經在繼續開發,但通常情況下為了準確地重現客戶問題以便做出修復,必須回退到 Git 標簽對應的代碼狀態。有時候新代碼可能已經修復了那個問題,但并非一直如此。通常你需要切換到特定的標簽并從那個標簽創建一個分支:

采用這六個 Git 協作策略,讓嵌入式團隊工作更高效

此外,如果帶附注的標記和帶簽名的標記有助于你的項目,可以考慮使用它們。

讓軟件運行時打印標簽

在大多數嵌入式項目中,從代碼版本構建出的二進制文件有固定的名稱,這樣無法從它的名稱推斷出對應的 Git 標簽。在構建時“嵌入標簽”有助于將未來發現的問題精準地關聯到特定的構建版本。在構建過程中可以自動地嵌入標簽。通常,git describe 生成的標簽字符串會在代碼編譯前插入到代碼中,以便生成的可執行文件能夠在啟時時輸出標簽字符串。當客戶報告問題時,可以指導他們給你發送啟動時輸出的內容。

總結

Git 是一個需要花時間去掌握的復雜工具。使用這些實踐可以幫助團隊成功地使用 Git 協作,無論他們的知識水平。
責編AJX

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

    關注

    5095

    文章

    19189

    瀏覽量

    307974
  • Linux
    +關注

    關注

    87

    文章

    11351

    瀏覽量

    210502
  • Git
    Git
    +關注

    關注

    0

    文章

    201

    瀏覽量

    15827
收藏 人收藏

    評論

    相關推薦

    嵌入式硬件電路設計的六個基礎知識

    嵌入式設計是龐大的工程,今天就說說硬件電路設計方面的幾個注意事項,首先,咱們了解下嵌入式的硬件構架。我們知道,CPU是這個系統的靈魂,所有的外圍配置都與其相關聯,這也突出了嵌入式設計
    發表于 11-18 11:36 ?1927次閱讀

    如何高效學習嵌入式

    是對的?  在這里我推薦大家學習51系列的單片機,學好了就能畢業出去生存而學習了51+canbus能夠你如虎添翼;  三、 分模塊學習嵌入式系統  任何一門學問,難得就是入門;而入門,就是要有一完整的知識
    發表于 08-20 17:02

    嵌入式系統特點詳解 嵌入式系統的大特點

    分享嵌入式系統的大特點是什么?  嵌入式系統特點詳解 嵌入式系統的大特點:  1、嵌入式系統
    發表于 06-15 13:34

    嵌入式系統特點詳解 嵌入式系統的大特點

    分享嵌入式系統的大特點是什么?  嵌入式系統特點詳解 嵌入式系統的大特點:  1、嵌入式系統
    發表于 06-23 11:01

    嵌入式系統特點詳解 嵌入式系統的大特點

    分享嵌入式系統的大特點是什么?  嵌入式系統特點詳解 嵌入式系統的大特點:  1、嵌入式系統
    發表于 06-28 13:40

    ARM與嵌入式linux的六個入門建議

    由于很多人總問這個問題,所以這里做一總結供大家參考。這里必須先說明,以下的步驟都是針對Linux系統的,并不面向WinCE。也許你會注意到,現在做嵌入式的人中,做linux研究的人遠比做WinCE
    發表于 07-19 01:15

    嵌入式系統有什么安全技巧?

    中間人攻擊、黑客攻擊、間諜和篡改、內存數據錯誤——嵌入式系統面臨各種威脅。儒卓力GDPR專家團隊主管兼嵌入式和無線部門營銷總監Bertron Hantsche提供了六個安全技巧,以便增
    發表于 10-18 06:28

    如何嵌入式電路設計更高效

    MCU和電源的選擇您的嵌入式電路設計更高效
    發表于 04-02 07:16

    JPEG2000算法嵌入式塊編碼的DSP高效實現策略

    JPEG2000算法嵌入式塊編碼的DSP高效實現策略
    發表于 10-20 09:40 ?4次下載
    JPEG2000算法<b class='flag-5'>嵌入式</b>塊編碼的DSP<b class='flag-5'>高效</b>實現<b class='flag-5'>策略</b>

    基于ARM的嵌入式系統程序開發要點()--開發高效程序的技巧

    基于ARM的嵌入式系統程序開發要點()--開發高效程序的技巧
    發表于 10-25 11:31 ?4次下載
    基于ARM的<b class='flag-5'>嵌入式</b>系統程序開發要點(<b class='flag-5'>六</b>)--開發<b class='flag-5'>高效</b>程序的技巧

    六個ARM嵌入式系統設計實驗指導書資料免費下載

    本文檔的主要內容詳細介紹的是六個ARM嵌入式系統設計實驗指導書資料免費下載包括了:本文檔的主要內容詳細介紹的是五ARM嵌入式系統設計實驗指導書資料免費下載包括了:實驗一 開機自啟動程
    發表于 10-15 16:31 ?16次下載
    <b class='flag-5'>六個</b>ARM<b class='flag-5'>嵌入式</b>系統設計實驗指導書資料免費下載

    高效和快速學習嵌入式系統的步驟有哪些

    使你更容易上手,并幫助你專注于更為重要的事情。實際上,六個步驟旨在使學習嵌入式系統更加高效和快速。所以,讓我們看看這些步驟。
    發表于 03-17 11:33 ?6次下載
    <b class='flag-5'>高效</b>和快速學習<b class='flag-5'>嵌入式</b>系統的步驟有哪些

    六個步驟使學習嵌入式系統更加高效和快速

    使你更容易上手,并幫助你專注于更為重要的事情。實際上,六個步驟旨在使學習嵌入式系統更加高效和快速。所以,讓我們看看這些步驟。
    發表于 03-25 15:46 ?8次下載
    <b class='flag-5'>六個</b>步驟使學習<b class='flag-5'>嵌入式</b>系統更加<b class='flag-5'>高效</b>和快速

    六個方面了解嵌入式的硬件構架資料下載

    電子發燒友網為你提供六個方面了解嵌入式的硬件構架資料下載的電子資料下載,更有其他相關的電路圖、源代碼、課件教程、中文資料、英文資料、參考設計、用戶指南、解決方案等資料,希望可以幫助到廣大的電子工程師們。
    發表于 04-14 08:50 ?18次下載
    <b class='flag-5'>六個</b>方面了解<b class='flag-5'>嵌入式</b>的硬件構架資料下載

    嵌入式軟件接口怎么測試,嵌入式系統接口測試策略.doc

    嵌入式系統接口測試策略嵌入式系統接口測試策略摘要:在日益廣泛應用的嵌入式系統中,軟件測試因為系統平臺局限性需要重復下裝,耗費較大的測試資源與
    發表于 10-20 19:06 ?16次下載
    <b class='flag-5'>嵌入式</b>軟件接口怎么測試,<b class='flag-5'>嵌入式</b>系統接口測試<b class='flag-5'>策略</b>.doc
    主站蜘蛛池模板: 一个色综合网站 | 狠狠躁夜夜躁人人爽天天miya | www在线视频在线播放 | 91一区二区三区四区五区 | 私色综合网 | 91亚色视频在线观看 | 国产精品资源在线观看网站 | 午夜网站在线播放 | 日本理论在线观看被窝网 | 456亚洲人成影院在线观 | 欧美三级视频在线播放 | 色婷婷视频在线观看 | 久久精品国产精品亚洲人人 | 成人18视频拍拍拍拍拍拍 | 国产免费人人看大香伊 | 理论片免费午夜 | 成人精品久久 | 老师下面好紧 | 亚洲高清免费视频 | 久久久鲁| 男女一级特黄a大片 | 一区二区三区免费精品视频 | 国内精品久久影视 | 亚洲久优优色优在线播放 | 成人黄色在线 | 中文字幕一二三四区2021 | 欧美一区二区视频在线观看 | 免费黄色一级毛片 | 国内一区二区三区精品视频 | 久久久久88色偷偷免费 | 香蕉色网| 午夜神马福利免费官方 | 国产亚洲3p一区二区三区 | 午夜伦理片在线观看 | 午夜啪视频 | 99国产国人青青视频在线观看 | 羞羞答答xxdd影院欧美 | 免费观看做网站爱 | 又粗又长又大又黄的日本视频 | 亚洲色图20p | 亚洲午夜视频 |