git命令操作(从小白到大佬)

2024-03-04 09:48

本文主要是介绍git命令操作(从小白到大佬),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  • git的配置
    • 第一次安装git需要配置用户名和邮箱
    • git config --global user.name 'xxx'
    • git config --global user.email 'xxx@xxx.com'
  • git的三区
    • 工作区
      • 开发代码的地方
      • 新建/修改/删除文件出现再工作区
    • 暂存区
      • 暂时保存代码的地方
    • 版本区
      • 代码版本控制的地方
  • 指令
    • git init 初始化一个空的git仓库(只要做一次,第二次会报错)
    • git add a.js 将位于工作区的a.js文件添加到暂存区
    • git add ./ */ -A 将工作区全部文件添加到暂存区
    • git commit -m '注释' 将暂存区全部代码添加到版本区进行版本控制
    • git status 查看当前文件的状态
      • 红色:说明文件位于工作区
      • 绿色:说明文件位于暂存区
      • 没有颜色/显示:说明文件位于版本区
    • git diff 对比(工作区和暂存区)文件差异
      • git diff --cached 暂存区和版本区
      • git diff master 工作区和版本区
  • 版本回退
    • git log 查看版本历史记录
    • git reflog 查看简版的历史纪录
    • git reset --hard HEAD^ 回退到上一个版本
    • git reset --hard commit_id 回退指定commit_id的版本
  • 分支操作
    • git checkout master 切换到master分支
    • git branch dev 新建dev分支
    • git checkout -b dev 新建并切换到dev分支(将当前分支内容复制到dev分支上)
    • git branch 查看当前有哪些分支
    • git branch -r 查看当前所有分支
    • git merge dev 在当前分支合并dev分支内容
相关需求场景的操作
  • 需求1:远程github已经创建一个仓库,需要将本地项目托管到远程github仓库中

    • git init
    • git add .
    • git commit -m “first commit”
    • git remote add origin https://github.com/sxzxiaofeng/test.git 将本地仓库和远程仓库关联起来
    • git remote rm(remove) origin* 删除关联的远程仓库
    • git push -u origin master 将本地仓库master分支的内容推送到远程仓库去 首次需要加上-u,后面就不需要了~
  • 需求2:远程有仓库并且有内容,下载到本地来使用

  • git clone https://github.com/sxzxiaofeng/test.git

  • 自动关联了,不需要关联, 克隆下来的仓库默认只有master分支。希望获取dev分支内容

  • git fetch origin dev1:dev2

  • 拉取远程仓库dev1分支的内容到本地的dev2分支上

  • 需求3:本地仓库有内容,远程有更新,本地拉取更新的内容

  • git pull origin master 拉取远程仓库的master分支合并到本地master分支上
    注意: 不管将来push、pull操作,都得先进行本地版本控制

    • git add .
    • git commit -m ‘xxx’
团队开发git操作流程

1.克隆仓库到本地 git clone https://github.com/sxzxiaofeng/test.git

2.建立连接 git remote add origin https://github.com/sxzxiaofeng/test.git

3.创建并切换分支 git checkout -b dev

4.将工作区文件提交到暂存区git add *

5.将暂存区代码添加到版本区进行版本控制 git commit -m ‘注释’

6.和远程仓库建立连接,并把dev分支上的代码推送到远端
git push --set-upstream origin dev (第一次连接需要输入密码),以后是git push origin dev

git pull —rebase origin master 把当前提交的commit移到分支的最顶端
git revert b3ce1c2e(版本号) 反转后重新提交,去除掉当前commit
使用 git revert 可以撤销指定的提交, 要撤销一串提交可以用 … 语法。 注意这是一个前开后闭区间,即不包括 commit1,但包括 commit2。
git revert --no-commit f7742cd…551c408
git commit -a -m ‘This reverts commit 7e345c9 and 551c408’

git cherry-pick b3ce1c2e 新建分支,把当前commit挑拣到新的分支,只提交自己需要的commit

如果你只想修改最后一次注释(就是最新的一次提交),那好办:
git commit --amend
git commit --amend -m ‘xxxx’ // 覆盖上次commit信息

出现有注释的界面(你的注释应该显示在第一行), 输入i进入修改模式,修改好注释后,按Esc键 退出编辑模式,输入:wq保存并退出。ok,修改完成。

查看提交历史图形
git log --graph --pretty=oneline --abbrev-commit(简写commit版本好)

使用–no-ff参数禁用快速合并模式
合并分支时,加上–no-ff参数就可以用普通模式合并,合并后的历史有分支,能看出来曾经做过合并,而fast forward合并就看不出来曾经做过合并。
git merge --no-ff -m “merge with no-ff” dev

Git pull提示需求输密码
Enter passphrase for key :
解决方案: ssh-add -k /Users/m/.ssh/id_rsa //后面这个是你放置私钥的目录

git常用命令:
git status
git log —oneline
git rebase origin/master
git branch -a
git rebase --skip
git rebase --continue
git rebase --abort
git merge
git commit --amend

这篇关于git命令操作(从小白到大佬)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/772794

相关文章

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

30常用 Maven 命令

Maven 是一个强大的项目管理和构建工具,它广泛用于 Java 项目的依赖管理、构建流程和插件集成。Maven 的命令行工具提供了大量的命令来帮助开发人员管理项目的生命周期、依赖和插件。以下是 常用 Maven 命令的使用场景及其详细解释。 1. mvn clean 使用场景:清理项目的生成目录,通常用于删除项目中自动生成的文件(如 target/ 目录)。共性规律:清理操作

git使用的说明总结

Git使用说明 下载安装(下载地址) macOS: Git - Downloading macOS Windows: Git - Downloading Windows Linux/Unix: Git (git-scm.com) 创建新仓库 本地创建新仓库:创建新文件夹,进入文件夹目录,执行指令 git init ,用以创建新的git 克隆仓库 执行指令用以创建一个本地仓库的

git ssh key相关

step1、进入.ssh文件夹   (windows下 下载git客户端)   cd ~/.ssh(windows mkdir ~/.ssh) step2、配置name和email git config --global user.name "你的名称"git config --global user.email "你的邮箱" step3、生成key ssh-keygen

查看提交历史 —— Git 学习笔记 11

查看提交历史 查看提交历史 不带任何选项的git log-p选项--stat 选项--pretty=oneline选项--pretty=format选项git log常用选项列表参考资料 在提交了若干更新,又或者克隆了某个项目之后,你也许想回顾下提交历史。 完成这个任务最简单而又有效的 工具是 git log 命令。 接下来的例子会用一个用于演示的 simplegit

记录每次更新到仓库 —— Git 学习笔记 10

记录每次更新到仓库 文章目录 文件的状态三个区域检查当前文件状态跟踪新文件取消跟踪(un-tracking)文件重新跟踪(re-tracking)文件暂存已修改文件忽略某些文件查看已暂存和未暂存的修改提交更新跳过暂存区删除文件移动文件参考资料 咱们接着很多天以前的 取得Git仓库 这篇文章继续说。 文件的状态 不管是通过哪种方法,现在我们已经有了一个仓库,并从这个仓

忽略某些文件 —— Git 学习笔记 05

忽略某些文件 忽略某些文件 通过.gitignore文件其他规则源如何选择规则源参考资料 对于某些文件,我们不希望把它们纳入 Git 的管理,也不希望它们总出现在未跟踪文件列表。通常它们都是些自动生成的文件,比如日志文件、编译过程中创建的临时文件等。 通过.gitignore文件 假设我们要忽略 lib.a 文件,那我们可以在 lib.a 所在目录下创建一个名为 .gi

取得 Git 仓库 —— Git 学习笔记 04

取得 Git 仓库 —— Git 学习笔记 04 我认为, Git 的学习分为两大块:一是工作区、索引、本地版本库之间的交互;二是本地版本库和远程版本库之间的交互。第一块是基础,第二块是难点。 下面,我们就围绕着第一部分内容来学习,先不考虑远程仓库,只考虑本地仓库。 怎样取得项目的 Git 仓库? 有两种取得 Git 项目仓库的方法。第一种是在本地创建一个新的仓库,第二种是把其他地方的某个

Git 的特点—— Git 学习笔记 02

文章目录 Git 简史Git 的特点直接记录快照,而非差异比较近乎所有操作都是本地执行保证完整性一般只添加数据 参考资料 Git 简史 众所周知,Linux 内核开源项目有着为数众多的参与者。这么多人在世界各地为 Linux 编写代码,那Linux 的代码是如何管理的呢?事实是在 2002 年以前,世界各地的开发者把源代码通过 diff 的方式发给 Linus,然后由 Linus

集中式版本控制与分布式版本控制——Git 学习笔记01

什么是版本控制 如果你用 Microsoft Word 写过东西,那你八成会有这样的经历: 想删除一段文字,又怕将来这段文字有用,怎么办呢?有一个办法,先把当前文件“另存为”一个文件,然后继续改,改到某个程度,再“另存为”一个文件。就这样改着、存着……最后你的 Word 文档变成了这样: 过了几天,你想找回被删除的文字,但是已经记不清保存在哪个文件了,只能挨个去找。真麻烦,眼睛都花了。看