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

相关文章

Python 中的 with open文件操作的最佳实践

《Python中的withopen文件操作的最佳实践》在Python中,withopen()提供了一个简洁而安全的方式来处理文件操作,它不仅能确保文件在操作完成后自动关闭,还能处理文件操作中的异... 目录什么是 with open()?为什么使用 with open()?使用 with open() 进行

Linux ls命令操作详解

《Linuxls命令操作详解》通过ls命令,我们可以查看指定目录下的文件和子目录,并结合不同的选项获取详细的文件信息,如权限、大小、修改时间等,:本文主要介绍Linuxls命令详解,需要的朋友可... 目录1. 命令简介2. 命令的基本语法和用法2.1 语法格式2.2 使用示例2.2.1 列出当前目录下的文

Spring Boot项目部署命令java -jar的各种参数及作用详解

《SpringBoot项目部署命令java-jar的各种参数及作用详解》:本文主要介绍SpringBoot项目部署命令java-jar的各种参数及作用的相关资料,包括设置内存大小、垃圾回收... 目录前言一、基础命令结构二、常见的 Java 命令参数1. 设置内存大小2. 配置垃圾回收器3. 配置线程栈大小

Mysql表的简单操作(基本技能)

《Mysql表的简单操作(基本技能)》在数据库中,表的操作主要包括表的创建、查看、修改、删除等,了解如何操作这些表是数据库管理和开发的基本技能,本文给大家介绍Mysql表的简单操作,感兴趣的朋友一起看... 目录3.1 创建表 3.2 查看表结构3.3 修改表3.4 实践案例:修改表在数据库中,表的操作主要

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3

Java利用JSONPath操作JSON数据的技术指南

《Java利用JSONPath操作JSON数据的技术指南》JSONPath是一种强大的工具,用于查询和操作JSON数据,类似于SQL的语法,它为处理复杂的JSON数据结构提供了简单且高效... 目录1、简述2、什么是 jsONPath?3、Java 示例3.1 基本查询3.2 过滤查询3.3 递归搜索3.4

Python使用DrissionPage中ChromiumPage进行自动化网页操作

《Python使用DrissionPage中ChromiumPage进行自动化网页操作》DrissionPage作为一款轻量级且功能强大的浏览器自动化库,为开发者提供了丰富的功能支持,本文将使用Dri... 目录前言一、ChromiumPage基础操作1.初始化Drission 和 ChromiumPage

IDEA中Git版本回退的两种实现方案

《IDEA中Git版本回退的两种实现方案》作为开发者,代码版本回退是日常高频操作,IntelliJIDEA集成了强大的Git工具链,但面对reset和revert两种核心回退方案,许多开发者仍存在选择... 目录一、版本回退前置知识二、Reset方案:整体改写历史1、IDEA图形化操作(推荐)1.1、查看提

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件