git 分支管理和常用命令
1、创建并切换分支
git checkout -b dev (创建并切换分支)
git branch dev(创建分支)
git checkout dev(切换分支)
=== git switch(切换分支)
2、删除分支
git branch -d dev
git branch -D dev(丢弃一个完全没有被提交过的分支)
3、合并分支
git merge feature1(出现冲突解决后在提交) Fast Forward(模式)
git merge —no—ff -m “merge with no—ff” dev (禁用fast forward模式)(可以看到有合并)
4、git clone带有子模块的仓库时,默认子模块没有更新下载的
git submodule init/ git submodule update进行更新下载/git submodule update —init —recursive(把嵌套的所有都搞下来)
git clone —recurse-submodules urlxxxxx(默认是下载下来了)
git常用
git log —pretty=oneline —abbrev-commit
git log — graph (图形化) 可以看见图
一、未提交前(commit前)
1、git撤销add后的代码: git reset *.txt (把在暂存区的放到工作区)
2、git checkout -- test.txt (丢弃工作区的修改)
3、git reset HEAD *.txt(commit前,暂存区的文件丢弃修改)
4、git restore test.cpp(撤销修改)
二、提交后(commit后)
1、git撤销commit的代码: git reset --soft HEAD^ (==HEAD~1)
2、git撤销commit和add的代码: git reset --hard HEAD^(bug: 会把修改都丢弃掉)
3、 git改变commit的注释: git commit --amend
三、推送到远程后(push后)
1、 git 取消本次push代码: git reset --soft 版本号码
然后再git push -f(强推送)
四、实用 git stash 保存
1、git stash (保存未commit的代码)
2、git stash save ‘备注的内容’
3、git stash list (列出)
4、git stash apply(应用最近的stash)
5、git stash pop(应用最近一次的stash,随后删除记录)
6、git stash drop (删除最近一次的stash)
五、git revert(恢复相关提交引入的更改、工作树需要干净的)
自己提交了错误的代码,然后团队也有人提交了代码,想要撤销掉自己提交的代码
1、普通的提交
git revert commitHash
2、合并的提交(会提示错误)
git revert -m 1 commitHash (-m 1 使用1保留主分支代码)
六、git cherry-pick(将已经提交的commit,复制出新的commit应用到分支里)
1、git cherry-pick commitHash1 commitHash2
2、git cherry-pick --continue(发生冲突后,解决完冲突后继续复制)
3、git cherry-pick -- abort(放弃cherry-pick)
4、git cherry-pick -- quit (退出cherry-pick)
七、实用git reflog
1、 查看commit 的所有记录
还没有评论,来说两句吧...