Android Studio配置Git及Git檔案狀態說明

來源:互聯網
上載者:User

標籤:

Android Studio配置Git還是比較簡單的,麻煩的是可能中間出現各種問題。如果你想瞭解或感興趣,請往下看。

首先你得下載Git用戶端,網址:http://git-scm.com/download/。

根據需要下載相應的版本,並安裝。然後在Android Studio中指定git.exe,點擊“Test”,成功則會彈出以下提示。

由於我用的是Android Studio 2.0 Preview,根本不存在“Enable Version Control Integration”提示,害我找了半天 T~T。其實有個類似的操作。

就是這個“Create Git Repository”,不然你會一直得到“...such that source detected in git but Unregistered Vcs root detected”提示。以示中unregistered roots上面的兩個工程就完成了配置。

完成了這一步,往下就是為git添加remote了。我使用開源中國線上代碼託管,先得到一個地址:https://git.oschina.net/***.git.

開啟git base,並切換到項目的根目錄,輸入以下命令

git remote add origin https://git.oschina.net/***.git

順利的話這一步就完成了。

然後在Android Studio中進行git add操作。

接著就是commit directory,最後push代碼到遠程倉庫。

至此,一次提交結束。

預設情況下,Android Studio的項目會有這幾個檔案夾:build, libs, src. 但每次提交代碼到git,都會提示build檔案夾中的眾多需要提交的檔案,其實我們根本不關心build檔案夾中的檔案改動情況。怎麼辦呢?利用.gitignore把它過濾掉。

在工程根目錄建立.gitignore檔案,然後添加

build

就這麼簡單!如果你想過濾其它檔案,添加相應的規則就可以了。

儲存.gitignore檔案後,還需要運行一下以下幾個命令,以便把.gitignore檔案提交到git上。

git rm -r --cached .git add .git commit -m "添加.gitignore檔案"git push origin master

“git rm -r -- cached 某個目錄”,這個命令有點狠,會把目標目錄清空,--cached .(注意:此處表示所有的檔案,有一個點);"git add .",再把所有的檔案重新加入緩衝(stages new and modified, without deleted)。如果你當前其它檔案已經是最新且已經push到遠程倉庫,完全可以用add .gitignore了事。

此外,還可以用以下命令代替git rm -r --cached .

git add -A

表示stages All。新手可能不太明白。好,我從git中的三種檔案狀態及其轉換說起。

---------------------------------------------------------------------------------------------

華麗的分隔線

---------------------------------------------------------------------------------------------

1、首先,我在git對應的工程目錄下建立一個test.txt,並輸入以下字串並儲存。

Hello

2、開啟git bash,輸入命令git status,查看檔案狀態

你會看到,紅色的test.txt處於待提交狀態,這個檔案被標記為Untracked files,並建議你使用git add <file>...命令將檔案包含到待提交清單中。

3、按照提示,使用命令git add test.txt,把這個檔案加入到git的快照中,再次git status

此時的test.txt狀態變成了Changes to be committed,等待被提交。然後同時它還提示你,利用git reset HEAD <file>...可以將檔案狀態還原成為暫存狀態,也即回到Untracked files狀態。

4、開啟test.txt,向其中加入些內容,儲存。

Helloworld

其實就多了world這個字串。再次用git status查看檔案狀態。

除了之前的“Changes to be committed”狀態,還多了“Changes not staged for commit”狀態,表明檔案已經被修改,但修改還沒有放入暫存地區,也就是沒產生快照。如果此時進行commit操作,只會提交"Hello",忽略“world”。

根據提示,如果想把最新的修改“Hello world”提交到倉庫,需要再次使用命令git add test.txt;如果想撤銷修改,即只想提交“Hello”,可以使用git checkout -- test.txt,再次git status,則可以看到狀態又改變了。

總結:所以,在檔案未進行commit操作之前,存在三種狀態:Untracked files, Changes not staged for commit, Changes to be committed. 每種狀態可以隨意轉換。

--------------------------------------------------------------------------------------------------------

題外話

--------------------------------------------------------------------------------------------------------

在git的後續版本中,添加了git stage作為git add的一個同義字,這樣在語義上更符合上面的Changes not staged for commit。為什麼要增加stage呢?

1、分批提交,降低commit的粒度。

2、檔案快照,便於回退。

如果一次提交過多檔案,對後續的復原或跟進無疑非常不利,對問題的定位也不便,體驗過估計清楚的。比如你做了兩個功能A和B,對應的檔案修改分別是a1.java, a2.java; b1.java, b2.java,提交時就可以這樣:

git stage a1.java a2.javagit commit -m "功能A"
git stage b1.java b2.javagit commit -m "功能B"

同時,每次修改後stage,任何時刻,都可以回到上一次staged的狀態:

git checkout -- test.txt

如果想從stage中刪除,則使用reset

git reset test.txt

這個命令就是git stage test.txt的反操作。

 

參考:知乎-為什麼要先git add才能git commit?

Android Studio配置Git及Git檔案狀態說明

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.