Android Studio配置Git及Git文件狀態說明


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,向其中加入些內容,保存。

Hello
world

其實就多了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.java
git commit -m "功能A"
git stage b1.java b2.java
git commit -m "功能B"

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

git checkout -- test.txt

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

git reset test.txt

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

 

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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM