GIT在iOS開發中的使用

来源:http://www.cnblogs.com/jgCho/archive/2016/04/08/5369026.html
-Advertisement-
Play Games

前言 在iOS開發中,很多公司對項目的版本控制管理都使用了git,當然也有部分公司使用的是svn。當年我最初接觸的是svn,覺得使用起來挺方便的,但是每次切分支都需要下載一份新的代碼起來,這實在太麻煩了,而且公司的網路下載一個項目的所有資源起來也有數百M,這還用工作麽? 當年,第一次聽說github ...


  

前言

iOS開發中,很多公司對項目的版本控制管理都使用了git,當然也有部分公司使用的是svn。當年我最初接觸的是svn,覺得使用起來挺方便的,但是每次切分支都需要下載一份新的代碼起來,這實在太麻煩了,而且公司的網路下載一個項目的所有資源起來也有數百M,這還用工作麽?

當年,第一次聽說github的時候,就聽說是使用git來管理的,可是那時的我感覺好複雜,不知道如何入手。如今,對git的使用可以說是很熟練了,不管是使用命令操作還是直接使用GUI界面工具操作。

就讓我帶著還不會使用git的同志,跨過那些我曾經走過的坑…

創建新倉庫

如果我們在本機上想要創建一個新的git倉庫,可以直接使用下麵的命令:

1 2 3   git init  

還有一種命令可以創建倉庫:

1 2 3   git init --bare  

我相信大家一定會疑問,這兩者有什麼區別呢?從字面上看,bare就是赤裸裸的意思,也就是說生成用於記錄版本庫歷史記錄的.git目錄下麵的文件而不會包含實際項目源文件的拷貝。進入版本目錄,會發現只有.git目錄下的文件。這個版本庫裡面的文件都是.git目錄下麵的文件,把原本在.git目錄裡面的文件放在版本庫的根目錄下麵;換句話說,不使用--bare選項時,會生成.git目錄以及其下的版本歷史記錄文件,這些版本歷史記錄文件就存放在.git目錄下;而使用--bare選項時,不再生成.git目錄,而是只生成.git目錄下麵的版本歷史記錄文件,這些版本歷史記錄文件也不再存放在.git目錄下麵,而是直接存放在版本庫的根目錄下麵。

這麼多說明是不是頭暈了?我們來來測試一下:

1 2 3 4 5 6 7 8 9   cd Desktop/ mkdir testgit1 cd testgit1 git init ls cd .git ls  

這裡在桌面創建一個目錄叫testgit1,進入到testgit1目錄下,然後執行git init來初始化一個倉庫。然後,就會生成一個.git目錄,然後查看當前目錄是否有文件?第一個ls命令是不是什麼也沒有?是的,預設.git目錄是隱藏的。我們進入到.git目錄下,查看:

1 2 3 4   HEAD        config      hooks       objects branches    description info        refs  

下麵簡單說明一下這幾個東東分別幹嘛用:

  • HEAD是個頭指針,在處理版本切換時,就是這個指針前移、後移等,因此只會生成快照而已,不會重新下載完整的一份代碼,所以切換隻需要幾秒鐘就可以在不同的分支上開發了。是不是很方便?
  • config是配置文件,想要看看內部有什麼東西,可以直接vi config查看。
  • hooks叫鉤子,主要是用於控制commitpush等操作動作,若需要深入瞭解,可百度,這個東西也是有很深的學問的。
  • objects是存儲所有的git對象,關於這個也可以百度閱讀相關文章,內容也很多。
  • branches自然是分支的意思,用於管理分支,裡面會有所有的分支。
  • description自然是描述信息
  • info這個目錄就不清楚具體是幹嘛用了
  • refs這個目錄有headstags,前者不清楚其用意,後者就是標簽,比如我們支持cocoapods的開源庫中升級就需要設置tag,對應版本。

git init初始化的版本庫,用戶可在該目錄下執行所有git操作,但別的用戶在將push上來的時候容易出現衝突。因此,實際中會將遠程伺服器端創建一個倉庫時,才會使用--bare,而我們個別用戶在創建倉庫時,不使用--bare

克隆版本

如果是本地的git倉庫,就直接使用下麵的命令,其中/path/to/repository是絕對路徑:

1 2 3   git clone /path/to/repository  

如果是在遠程伺服器這邊的倉庫,可以用這樣的命令。其中username公司給你開的git用戶,host是你們公司放置項目代碼的伺服器,/path/to/repository是遠程git倉庫的訪問路徑:

1 2 3   git clone username@host:/path/to/repository  

工作流

首先,我們需要理解git版本控制的工作流:

本地倉庫由工作目錄,它持有實際文件;第二個是緩存區,它像個緩存區域,臨時保存你的改動;最後是HEAD,指向你最近一次提交後的結果。

看看官方的圖解:

image

其流程:當前working dir通過add命令添加到stage緩存區中,再通過commit命令提交,HEAD就指向了這次提交的結果。

add命令添加

使用下麵的命令添加到緩存區,其中第一行代碼是只提交一個文件到緩存區,而第二行代碼是添加所有有改動的文件到緩存區:

1 2 3 4   git add <filename> git add *  

commit命令提交本地

然後我們就可以通過commit提交,其中-m選項是comment的意思,也就是註釋,後面跟著一行註釋說明:

1 2 3   git commit -m "代碼提交信息"  

執行完commit後,現在,所做的改動已經提交到了HEAD,但是還沒到提交到遠端倉庫。

push命令推到遠端

你的改動現在已經在本地倉庫的HEAD中了,執行如下命令以將這些改動提交到遠端倉庫:

1 2 3   git push origin master  

可以把master換成你想要推送的任何分支。 如果當前我們不是在主幹上開發,我們提交的代碼是要提交到當前正在開發的分支上。假設當前正在開發的分支名稱叫:Double11Activity表示雙11活動分支。那麼我們所做的改動應該推送到Double11Activity分支上。

1 2 3   git push origin Double11Activity  

remote add添加遠端倉庫

如果你還沒有克隆現有倉庫,並欲將你的倉庫連接到某個遠程伺服器,你可以使用如下命令添加:

1 2 3   git remote add origin <server>  

其中server就是我們遠程git伺服器的訪問路徑。比如:

1 2 3   git remote add origingit@182.92.160.41:/data/git/demo.git  

查看倉庫是否已經添加到遠端git倉庫,可使用下麵的命令:

1 2 3   git remote -v  

如果出現類似這樣:

1 2 3 4   origin  git@server:/Data/git/ios/demo.git (fetch) origin  git@server:/Data/git/ios/demo.git (push)  

假設系統是CentOS系統,其中,git是用戶,server是伺服器地址,/Data/git/ios/demo.git是具體的項目倉庫目錄訪問地址。

有了這些,我們就能夠將本地改動推送到所添加的伺服器上去了。

pull命令拉代碼

想想多人同時開發時,除了你自己會發動代碼之外,其他同事也會改動代碼並提交到遠端倉庫,因此我們每次在提交之前,都應該先pull一下,將其他同事最新的代碼拉下來。如果有衝突,則需要先解決衝突,然後合併,且在xcode編譯運行通過,再將代碼推送到遠端倉庫。

拉最新代碼的命令就很容易了:

1 2 3   git pull  

如果出現衝突,一定要解決,否則工程就打不開。如果解決不好,且在本機沒有在xcode上跑通,那麼一旦提交到遠端,其他同事一拉代碼,就會導致無法打開,或者編譯不通過,會影響他人的工作。

分支branch

分支是用來將敏捷開發的根本。在你創建倉庫的時候,master是“預設的”,通常用做主幹。在其它分支上進行開發,完成後再將它們合併到主幹上。

image

創建一個叫做feature_x的分支,並切換過去:

1 2 3   git checkout -b feature_x  

如果只是創建一個分支而不自動切換到該分支上,可以這樣:

1 2 3   git checkout feature_x  

想要切換到master上,這樣:

1 2 3   git checkout master  

刪除分支:

1 2 3   git branch -d <分支名>  

通常在開發中,每一期的需求在開發之前,都需要建立一個新的分支,併在這個分支上開發。創建之後,我們還需要推送到遠端,不然其他同事無法一起參與開發。

1 2 3 4   git branch -b <branchname> git push origin <branchname>  

合併分支:

1 2 3   git merge <branch>  

合併方法:如果要將分支A合併到分支B,那麼應該這樣:先切換到B分支,然後執行命令:

1 2 3   git merge A  

也就是說,A要合併B,就要先切換到A分支,再執行合併命令。如果是B要合併A,就需要先切換到B分支,然後再合併A分支。

對於多人同時開發,尤其多團隊敏捷開發的大團隊,代碼合併是非常麻煩的事。今天下午將其他團隊剛上線的版本合併到主幹,再將主幹合併到當前我們團隊與其他團隊抽人共同開發的分支上,解決衝突就花了4個小時。

好在沒有沒有動storybard/xib這些地方,合併也就幾個小時就可以了。如果上一期開發做了很多的界面改動,而這個界面原來是由sb/xib開發的話,合併過來就困難了,那些是很難讀懂的一串串的東西,不知如何調。因此,對於大團隊開發,真的不建議使用xib/sb來開發。

合併之前,可以先查看當前分支與待合併過來的分支的有什麼不同:

1 2 3   git diff <source_branch> <target_branch>  

註意事項

通常上線的分支都是master,也就是主幹,因此在實際開發中,必須保證主幹永遠是最乾凈的,只能將主幹代碼合併到其他分支,然後測試通過並上線後,再合併到主幹上

推薦git界面軟體:SourceTree

這個軟體對於那些不懂命令,也不想用命令的開發者來說,這個軟體就是一大福利。

image

我們可以直接將本地的倉庫直接添加進來,也可以克隆遠端倉庫到本地。點擊新倉庫就可以添加了,其中有四個選項,我們會選擇第一個:從URL克隆,也就是git訪問地址。

image

這裡面有很多個操作,每個就是對應於一個命令,如果不想使用命令操作,可以直接使用這個。

在實際開發中,解決衝突時,我還是要使用這個軟體來解決的,因此衝突文件有時候會達到上百個類文件衝突,要花一天時間來解決衝突。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Angularjs中,$http以post在消息體中傳遞參數,需要做以下修改,以確保消息體傳遞參數的正確性。 一、在聲明應用的時候進行設置: 1 var httpPost = function ($httpProvider) { 2 /******************************** ...
  • 真的是長見識了,JavaScript居然能做除了WEB界面外運行於任何平臺的APP,而且可以做伺服器端,還有天理和王法嗎?JavaScript到底有多神奇,要不要重新上路,老程式員何去何從,自然要先網上查查。不墨跡,直接上硬貨,自己看吧。 http://www.zhihu.com/question/... ...
  • js函數調用方式大概可分為:函數調用,構造器調用,call或apply,方法調用四種方式。下麵結合一些基礎概念和實測代碼,從函數調用的角度,探討JavaScript中this的用法。 1. new對函數調用的影響 先看JScript手冊中對new和構造函數的解釋: 實測: 結論:構造器方式this指 ...
  • 昨天記錄了棧方法和隊列方法。今天把餘下的幾種方法也記錄下來。 (一)重排序方法 reverse()方法可以反轉數組的順序。例如: var num=[1,4,5,2,7]; num.reverse(); alert(num);//輸出7,2,5,4,1 sort()方法則是按升序排列數組,即從小到大排 ...
  • 在慕課網上學習了五子棋的課程,感覺挺不錯。然後自己寫了個關於五子棋的android程式,從中還是能夠學習到很多東西的。現在我們開始今天五子棋程式的編寫歷程。程式的源碼請參見友情鏈接: 目錄導航 好了,我們現在開始一步步的構建出項目來,首先是如下的項目結構圖: 運行的效果圖: 一些前期做準備的代碼 一 ...
  • App Store: Pinyin Comparison 拼音辨別 做了一新個圖標,至少比上一個好多了。拼音應用的圖標大多千篇一律,這回嘗試做個不一樣的。 簡化了首頁顏色,首頁的黑色換成了金色,看著更舒服。主題藍色,金色都變淺了點,不再那麼暗。 上一個版本星期日提交,審核了一個星期。這個版本星期二提 ...
  • 本文轉自文頂頂,稍加修改 1.for迴圈 要遍歷字典、數組或者是集合,for迴圈是最簡單也用的比較多的方法 優點:簡單 缺點:由於字典和集合內部是無序的,導致我們在遍歷字典和集合的時候需要藉助一個新的『數組』作為中介來處理,多出了一部分開銷。 2.for....in....遍歷 在Objective ...
  • 在github上面有很多的第三方類庫,大大節約了大家的開發時間 下載地址:https://github.com/gsdios/SDCycleScrollView 現已支持cocoapods導入:pod 'SDCycleScrollView','~> 1.61' 效果 具體實現代碼 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...