Git 聚焦于文件的更改而非文件本身。當你說 Git 添加文件時, 你并非在告訴 Git 要添加文件到倉庫。而是說 Git 應當對文件 的當前狀態做記錄以便稍后提交。
我們將嘗試在本次實驗中探索其中的差異。
### 初次更改:允許默認名稱
如果命令行參數未提供,更改“Hello, World”程序來接受一個 默認值。
~~~
name = ARGV.first || "World"
puts "Hello, #{name}!"
~~~
### 添加更改
現在添加此次更改到 Git 的暫存區。
~~~
$ git add hello.rb
~~~
### 二次更改:添加注釋
現在給“Hello, World”程序添加一行注釋。
~~~
# Default is "World"
name = ARGV.first || "World"
puts "Hello, #{name}!"
~~~
### 檢查當前狀態
~~~
$ git status
~~~
你應該看到:
~~~
$ git status
# On branch master
# Changes to be committed:
# (use "git reset HEAD <file>..." to unstage)
#
# modified: hello.rb
#
# Changes not staged for commit:
# (use "git add <file>..." to update what will be committed)
# (use "git checkout -- <file>..." to discard changes in working directory)
#
# modified: hello.rb
#
~~~
注意 hello.rb 在狀態中被列了兩次。第一次更改已被暫存,且 準備提交。第二次更改還未暫存。如果你現在提交,那么注釋不 會保存到倉庫中。
讓我們試試看。
### 提交
提交暫存的更改,然后重新檢查狀態。
~~~
$ git commit -m "Added a default value"
$ git status
~~~
你應該看到:
~~~
$ git commit -m "Added a default value"
[master 582495a] Added a default value
1 files changed, 3 insertions(+), 1 deletions(-)
$ git status
# On branch master
# Changes not staged for commit:
# (use "git add <file>..." to update what will be committed)
# (use "git checkout -- <file>..." to discard changes in working directory)
#
# modified: hello.rb
#
no changes added to commit (use "git add" and/or "git commit -a")
~~~
`status`?命令將告訴你 hello.rb 還有未記錄的更改,且不在暫存 區。
### 添加第二次更改
現在添加第二次更改到暫存區,然后執行?`git status`。
~~~
$ git add .
$ git status
~~~
注意:我們使用當前目錄(.)作為要添加的文件。這是一種 添加當前目錄及其子目錄下所有更改文件的習慣簡寫方式。 但因為它添加所有東東,所以在做?`add .`?前檢查狀態是一 個好主意,只是為了確定你沒有添加不想要的文件。
我想你已經明白了?`add .`?這個技巧,但為了安全在余下的 教程中我們將繼續直接添加文件。
你應該看到:
~~~
$ git status
# On branch master
# Changes to be committed:
# (use "git reset HEAD <file>..." to unstage)
#
# modified: hello.rb
#
~~~
現在第二次已經暫存,且準備提交。
### 提交第二次更改
~~~
$ git commit -m "Added a comment"
~~~
- 關于
- 1. 設置
- 2. 再談設置
- 3. 創建項目
- 4. 檢查狀態
- 5. 做更改
- 6. 暫存更改
- 7. 暫存與提交
- 8. 提交更改
- 9. 更改而非文件
- 10. 歷史
- 11. 別名
- 12. 獲得舊版本
- 13. 給版本打標簽
- 14. 撤銷本地更改
- 15. 撤銷暫存的更改
- 16. 撤銷提交的更改
- 17. 從分支移除提交
- 18. 移除 oops 標簽
- 19. 修正提交
- 20. 移動文件
- 21. 再談結構
- 22. Git 內幕:.git 目錄
- 23. Git 內幕:直接處理 Git 對象
- 24. 創建分支
- 25. 導航分支
- 26. 在 master 中更改
- 27. 查看分叉的分支
- 28. 合并
- 29. 創建沖突
- 30. 解決沖突
- 31. 變基 VS 合并
- 32. 重置 greet 分支
- 33. 重置 master 分支
- 34. 變基
- 35. 合并回 master
- 36. 多個倉庫
- 37. 克隆倉庫
- 38. 回顧克隆的倉庫
- 39. 何為 Origin?
- 40. 遠程分支
- 41. 更改原始倉庫
- 42. 取得更改
- 43. 合并拉下的更改
- 44. 拉下更改
- 45. 添加跟蹤的分支
- 46. 裸倉庫
- 47. 添加遠程倉庫
- 48. 推送更改
- 49. 拉下共享的更改
- 50. 托管你的 Git 倉庫
- 51. 共享倉庫
- 52. 高級/將來的主題