git緩存區
A. git 暫存區有內容 可以切換分支嗎
如果是儲藏未提交的內容,用git stash 如果是已提交的內容,則無需操作,本地庫已經保存了
B. git 為什麼要設立緩存區
這樣在本地就可以提交代碼和回滾代碼,而不用連接伺服器的時候才能做相關操作。
C. 為什麼git在暫存區之前還要有一個add的過程
用戶在實際工作中,有點修改可以先暫存,不滿意可以再修改,方便,如果直接提交到倉庫,錯了就比較麻煩了,造成提交歷史比較混亂。
D. git中為什麼要有暫存區感覺暫存區沒有必要存在的,
暫存區可以使你離線時在本地進行工作,聯網後再提交,還是有用的
E. git checkout與git reset有啥區別嗎
git reset用於撤銷操作。
git reset [--hard | --mixed | --soft] [<commit>]
--hard 會執行下圖中操作123,參數hard會同時改變版本庫的HEAD引用指向,緩存區內的內容,以及工作空間的內容,執行之後HEAD引用會指向commit指向的版本,同時緩存區內的內容也會以版本庫HEAD指向的版本進行刷新,工作空間內的內容也會以HEAD引用指向的代碼版本進行替代。
--mixed 會執行下圖中操作12 在該參數的情況下,工作空間內的內容不會被刷新,只會更新HEAD引用的指向以及緩存區的內容
--soft 會執行下圖中操作1 只會改變HEAD引用的指向
git checkout一般用於切換分支,也可以用來回退代碼
git checkout branchName切換分支到指定的分支上,使用的時候,需要注意,使用該命令工作空間下的內容會被指定的分支內容覆蓋,在之前分支上面所做的沒有提交的變動會丟失。 如果需要新建一個分支並使用新的分支,我們可以使用git checkout -b dev,這樣我們就新建了一個名為dev的分支,並切換到該分支下面。
該命令默認以HEAD引用來創建分支,需要需要使用指定的版本號來創建分支,可以在後面跟上版本號。
F. 百思不得其解,tortoisegit是把git中的暫存區概念幹掉了嗎
stage(暫存)這個概念在TortoiseGit中依然存在,只是變得不直觀了
原因:
TortoiseGit為了保持和TortoiseSVN近乎一致的使用體驗,對「暫存文件」這個步驟進行了操作上的簡化:操作者點擊提交按鈕的瞬間,TortoiseGit會立即stage(暫存)這些文件並commit(提交)它們。注意,這兩個操作幾乎是先後同時執行的
也就是說,TortoiseGit通過緊密的捆綁git add和git commit這兩個指令到一個提交按鈕中,在操作層面給人了一種暫存(stage)被幹掉了的感覺,但實際上並沒有!
在大部分情況下,這個TortoiseGit特有的優化會給帶來一些便利
但同時也會導致TortoiseGit對暫存區的表現變得非常不直觀。比如TortoiseGit根本沒有提供任何一個窗口來表現哪些文件處於暫存區
所以建議,在windows系統下,如果你不擅長通過命令行來使用git,請常備TortoiseGit和SourceTree這2個Git GUI
G. git如何撤銷通過Add添加所有文件到緩存區的
一,常規的操作 1, 首先按需修改文件 echo >> lz66303.txt 2, 然後按需提交被修改的文件到HEAD緩存區 git add lz66303.txt 3, 再把這個修改記錄到分支中
H. git 不小心把暫存區的文件 reset掉了 怎麼恢復
已經解決了
,我就自問自答了直接
git
reset
-hard
版本號
就可以恢復本地的文件夾了(git
log
查看版本號)
I. 什麼指令可以看git 暫存區的東西
git ls-files -s