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