git

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 远端分支

   转载规则


《git》 朝飞 采用 知识共享署名 4.0 国际许可协议 进行许可。
 上一篇
JS基础知识点及常考面试题 JS基础知识点及常考面试题
原始类型有哪几种?null 是对象嘛?原始类型有6种 string number boolean null undefined symbol 原始类型存储的都是值,没有函数调用 比如undefined.toString();会报错 ‘1’
2020-05-11
下一篇 
leetcode-数组-219-存在重复元素2 leetcode-数组-219-存在重复元素2
描述 给定一个整数数组和一个整数 k,判断数组中是否存在两个不同的索引 i 和 j,使得 nums [i] = nums [j],并且 i 和 j 的差的绝对值最大为 k。 示例 1: 输入: nums = [1,2,3,1], k
2020-02-28
  目录