git总结
本地操作
查看变更情况
git status将当前目录及其子目录下所有变更都加入到暂存区
git add .比较工作区和暂存区的所有差异
git diff比较某文件工作区和暂存区的差异
git diff 文件名比较暂存区和 HEAD 的所有差异
git diff --cached比较某文件暂存区和 HEAD 的差异
git diff --cached 文件名创建commit
git commit将暂存区和工作区所有文件恢复成和 HEAD 一样
git reset --hard将未处理完的变更先保存到 stash 中
git stash临时任务处理完后继续之前的工作
- apply 保留 stash
- pop 不保留 stash
git stash pop git stash apply
查看所有 stash
git stash list取回某次 stash 的变更
git stash pop stash@{数字n}
分支操作
基于当前分支创建新分支
git branch 新分支名基于指定分支创建新分支
git branch 新分支 指定分支基于某个 commit 创建分支
git branch 新分支 某个分支的commit id安全删除本地某分支
git branch -d 本地分支强行删除本地某分支
git branch -D 要删除的分支将 A 分支合入到当前分支中且为 merge 创建 commit
git merge A分支将 A 分支合入到 B 分支中且为 merge 创建 commit
git merge A分支 B分支将当前分支基于 B 分支做 rebase,以便将B分支合入到当前分支
git rebase B分支将 A 分支基于 B 分支做 rebase,以便将 B 分支合入到 A 分支
git rebase B分支 A分支
变更历史
当前分支各个 commit 用一行显示
git log --oneline显示就近的 n 个 commit
git log -n用图示显示所有分支的历史
git log --oneline --graph --all查看涉及到某文件变更的所有 commit
git log 文件某文件各行最后修改对应的 commit 以及作者
git blame 文件
标签操作
查看已有标签
git tag新建标签
git tag v1.0新建带备注标签
git tag -a v1.0 -m '备注'给指定的 commit 打标签
git tag v1.0 commit id推送一个本地标签
git push origin v1.0推送全部未推送过的本地标签
git push origin --tags删除一个本地标签
git tag -d v1.0
远端交互
查看所有远端仓库
git remote -v添加远端仓库
git remote add url删除远端仓库
git remote remove remote的名称重命名远端仓库
git remote rename 旧名称 新名称将远端所有分支和标签的变更都拉到本地
git fetch remote把远端分支的变更拉到本地,且 merge 到本地分支
git pull origin 分支名删除远端分支
git push remote --delete 远端分支