git 使用

如果有问题请各位大佬指出,毕竟代码版本很重要!别误人子弟😊

在使用git开发的时候,经常会需要切换原来的版本。

1.git checkout commitID可以切换到commit参数指定的版本,但是需要注意的是,这个是脱离了原来的分支,修改本地文件以及git commit提交操作都不会影响之前的分支。可以使用git switch - 切换回原来的分支

2.如果想将远程分支和本地分支都切换为原来的某个版本

**git reset --hard <commit>**将git的HEAD指针指向到commit对应的版本,本地文件内容也会回退,不需要再执行git checkout命令来回退本地文件内容(我感觉是git reset <commit> + git checkout [--] <filepath>的结合)

  • 这个命令会回退git log的信息,但是可以使用git log -g看到所有操作过程的commit信息
  • 这个操作会导致本地分支落后远程仓库1个提交,可以使用快进(fast-forward)将本地分支更新到远程分支的最新状态 "Your branch is behind 'origin/xxx' by 1 commit, and can be fast-forwarded. (use "git pull" to update your local branch)"
bash 复制代码
1.git fetch 获取远程分支的最新更新,但是不会自动合并到当前分支
2.git diff origin/xxx 查看本地分支和远程分支之间的差异
3.git merge origin/xxx 手动合并远程分支的更改到本地分支

这种操作适用于查看当前修改和之前某次提交修改的差别

  • 如果想要在之前的分支上继续开发呢?

    bash 复制代码
    1.git stash 将当前的更改暂存起来,方便后续恢复使用(我认为这就是栈的操作),
    如果已经push过远程,我认为可以不用,后续直接根据 commitID获取就可以了
    2.git push --force origin xxx 将本地分支的更改强制推送到远程分支上

    参考: https://segmentfault.com/a/1190000020863861

相关推荐
ice___Cpu6 小时前
Git - 1( 14000 字详解 )
大数据·git·elasticsearch
范纹杉想快点毕业1 天前
以项目的方式学QT开发(一)——超详细讲解(120000多字详细讲解,涵盖qt大量知识)逐步更新!
c语言·数据结构·c++·git·qt·链表·github
qq_653644461 天前
如何查看打开的 git bash 窗口是否是管理员权限打开
开发语言·windows·git·bash
tonngw1 天前
【Mac 从 0 到 1 保姆级配置教程 12】- 安装配置万能的编辑器 VSCode 以及常用插件
git·vscode·后端·macos·开源·编辑器·github
橄榄熊1 天前
Git 常用命令详解
git
o(╥﹏╥)2 天前
绑定 SSH key(macos)
开发语言·git·学习·macos
半新半旧2 天前
Git 分支指南
git
qq_464357012 天前
git中忽略文件.gitignore文件的用法
git
程序员阿鹏2 天前
Git的安装和配置(idea中配置Git)
java·开发语言·ide·git·intellij-idea·idea
belldeep3 天前
如何阅读、学习 Git 核心源代码 ?
git·学习·源代码