加强记忆,都是廖雪峰的东西哈。https://www.liaoxuefeng.com/wiki/896043488029600/896067074338496
背景:
CVS及SVN都是集中式的版本控制系统,而Git是分布式版本控制系统。
配置:
git config --global user.name "Autumn-Paint"
git config --global user.email "[email protected]"
git config --list
建立仓库--也可以克隆别人的:
git init
提交:
git add
git commit -m "message"
要随时掌握工作区的状态,使用git status命令。
如果git status告诉你有文件被修改过,用git diff可以查看修改内容。
查看工作区和版本库的差异:(上面那个是查看暂存区和工作区的差异)
git diff HEAD -- 文件名
恢复:
git log查看每次提交历史 。优化一下,git log --pretty=oneline
git reset --hard 1045a 退回到你想回去的提交(1045a是commitid,可以不用写全)
git reflog查看命令历史,可以退回到未来。找到未来的commitid,然会git reset就可以了。
撤回修改:(这个知道就好,git会有提示)
场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout -- file。退回到最近的git add 或者git commit状态。
场景2:当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD
场景3:已经提交了不合适的修改到版本库时,想要撤销本次提交,参考版本回退一节,不过前提是没有推送到远程库。
命令git rm用于删除一个文件。如果一个文件已经被提交到版本库,那么你永远不用担心误删,但是要小心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容。
克隆
git push origin master推送到远程仓库
git clone [email protected]:michaelliao/gitskills.git
分支:
查看分支:git branch
创建分支:git branch
切换分支:git checkout
创建+切换分支:git checkout -b
合并某分支到当前分支:git merge
删除分支:git branch -d
冲突解决:
git merge 分支之后,会提示是否有冲突,有的话,手动修改冲突,然后重新add,commit就可以了。
关于git merge
git merge --no-ff -m "merge with no-ff" dev 这个模式是普通模式,不加 --no-ff是快速模式,普通模式,合并会形成一个commit记录,快速模式下,合并后是没有记录的。
git stash保护工作现场
当手头工作没有完成时,先把工作现场git stash一下,然后去修复bug,修复后,再git stash pop,回到工作现场;
git stash list查看保存现场的有哪些
git stash pop 弹出保护现场的东西,并且把记录删除
git stash pop stash@{0} 根据你保护的序号弹出
在master分支上修复的bug,想要合并到当前dev分支,可以用git cherry-pick 命令,把bug提交的修改“复制”到当前分支,避免重复劳动。
强制删除分支:
git branch -D
将多个commit合并为一个:
git rebase -i HEAD~2这里是最近两次提交合并
记得将后面的pick改成s
变基
即更改本次分支提交的基准值为远程分支的基准值
例如:本地分支落后于远程release分支的情况;在本地分支rebase远程release分支,即可完成
git rebase origin/release
如果有冲突的话,需要进行解决冲突再使用下面命令
git rebase --continue
打标签:
git tag v1.0
git tag查看标签
默认标签是打在最新提交的commit上的。有时候,如果忘了打标签,比如,现在已经是周五了,但应该在周一打的标签没有打,怎么办?
方法是找到历史提交的commit id,然后打上就可以了:
比方说要对add merge这次提交打标签,它对应的commit id是f52c633,敲入命令:
git tag v0.9f52c633
命令git tag -a
git tag -d v0.1删除标签
git push origin v1.0推送到远程
命令git push origin
命令git push origin --tags可以推送全部未推送过的本地标签;
命令git tag -d
命令git push origin :refs/tags/
.gitignore文件:
忽略某些文件时,需要编写.gitignore;
.gitignore文件本身要放到版本库里,并且可以对.gitignore做版本管理!
#.gitignore不生效方法
.gitignore中已经标明忽略的文件目录下的文件,git push的时候还会出现在push的目录中,或者用git status查看状态,想要忽略的文件还是显示被追踪状态。
原因是因为在git忽略目录中,新建的文件在git中会有缓存,如果某些文件已经被纳入了版本管理中,就算是在.gitignore中已经声明了忽略路径也是不起作用的,
这时候我们就应该先把本地缓存删除,然后再进行git的提交,这样就不会出现忽略的文件了。
解决方法: git清除本地缓存(改变成未track状态),然后再提交:
```
git rm -r --cached .
git add .
git commit -m 'update .gitignore'
git push -u origin master
```