当前位置: 首页 > news >正文

【GIT】Idea中的git命令使用-全网最新详细(包括现象含义)

原文网址:【GIT】Idea中的git命令使用-全网最新详细(包括现象含义)

文章目录

  • **命令1:查看当前所处分支:**
  • **命令2:拉取最新代码:**
  • **命令3:切换分支:**
  • **命令4:从当前某个分支创建新分支:**
  • **命令5:建新分支并立即切换到该分支**
  • **命令6:删除分支**
  • **命令7:分支推送远程**
  • **命令8:分支合并**
  • 如果在UI操作中遇见了问题,又改怎么解决呢 ?

梳理记录一下,在IDEA中常用的git命令,希望能帮到小伙伴们~

命令1:查看当前所处分支:

D:\workspace\IdeaProjects\guliMall>git branch

现象:会显示出来当前所有的分支,并且当前分支会有特殊显示,前面带*标识
在这里插入图片描述

命令2:拉取最新代码:

D:\workspace\IdeaProjects\guliMall>git pull

现象1:这是远程分支没有更新的内容,所有没拉取到更新
在这里插入图片描述
现象2:这是代表 从远程拉取到了一些代码更新,其中fast-forward的更新的内容,其中绿色加号的代表一共有55处新增,红色的代表删除了一共有7处修改,有新增有删除
在这里插入图片描述

命令3:切换分支:

git checkout dev

现象1:代表本地从当前分支切换到dev分支;下面的提示代表已经成功切换到,并且切换后的dev分支内容和远程分支内容一致;
在这里插入图片描述

witched to branch 'master'
Your branch is up to date with 'origin/master'.

提示解释:这条信息表示你已经成功切换到了名为 ‘master’ 的分支,并且这个分支与远程仓库(origin)中的 ‘master’
分支是同步的,即你的本地 ‘master’ 分支是最新的,没有落后于远程仓库的 ‘master’ 分支。

在Git中,分支是用来并行开发不同功能的工具。‘master’
分支通常被用作主分支,包含稳定且可发布的代码。当你需要开始一个新的功能开发或修复一个bug时,你可能会创建一个新的分支来工作,以避免影响主分支的稳定性。完成工作后,你可以将这个新分支合并回
‘master’ 分支,或者将 ‘master’ 分支的更新合并到你的分支中,以保持代码的同步。

这条信息告诉你,你现在正在 ‘master’
分支上工作,并且这个分支是最新的,没有需要拉取的更新。如果你想要开始新的工作,你可能需要创建一个新的分支;如果你只是想确保你的
‘master’ 分支是最新的,那么你已经完成了这一步。

现象2:切换的分支名称错误
在这里插入图片描述
**现象3:**比如当前是dev分支,我切换到test分支之后,提示
Switched to branch ‘feature-20240828-test’
Your branch is ahead of ‘origin/feature-20240828-test’ by 4 commits.
(use “git push” to publish your local commits)
这条信息表示你已经成功切换到了名为 feature-20240828-test 的分支,并且这个分支在你的本地有4个提交是领先于远程分支 origin/feature-20240828-test 的。这意味着你在本地对这个分支做了一些修改(比如增加了新功能、修复了bug等),并且这些修改还没有被推送到远程仓库中。
在这里插入图片描述
针对于现象3中的情况,
如果你想要将这些修改分享给其他人,或者确保你的修改在远程仓库中得到保存,你需要执行 git push 命令。这个命令会将你本地的修改推送到远程仓库的 feature-20240828-test 分支上。

git push origin feature-20240828-test

执行 git push 时,你可能会遇到几种情况:

  • 成功推送:如果远程仓库的 feature-20240828-test 分支没有其他人的提交,或者即使有,Git 能够自动合并这些提交,那么你的推送将会成功。
  • 合并冲突:如果远程仓库的 feature-20240828-test 分支在你推送之前已经有了新的提交,并且这些提交与你本地的提交有冲突,Git 会阻止你推送,并要求你先解决这些冲突。这通常涉及到拉取远程仓库的最新更改(git pull 或 git fetch 后合并),解决任何冲突,然后再次尝试推送。
  • 权限问题:如果你没有足够的权限向远程仓库推送更改,Git 会显示一个错误消息。在这种情况下,你需要联系仓库的管理员来获取必要的权限。
    注意:在git push命令时 ,明确指定远程仓库和分支是一个好习惯,特别是当你处理多个远程仓库或多个分支时;

命令4:从当前某个分支创建新分支:

D:\workspace\IdeaProjects\guliMall>git branch dev

现象:控制台无提示
在这里插入图片描述
可以看到idea右下角已经出现了刚新建的dev分支;
在这里插入图片描述

命令5:建新分支并立即切换到该分支

命令: git checkout -b (branchname)

我们也可以使用 git checkout -b (branchname) 命令来创建新分支并立即切换到该分支下,从而在该分支中操作
在这里插入图片描述
在这里插入图片描述

命令6:删除分支

删除分支命令: git branch -d (branchname)

现象:是因为你当前就在dev分支,所以无法删除当前分支,如果你想删除dev分支,你需要先跳转到别的分支,然后再去删除这个分支之外的其他分支;
在这里插入图片描述
如下图所示,删除dev_test分支
在idea又下角可以看到dev_test分支消失了
在这里插入图片描述

命令7:分支推送远程

D:\workspace\IdeaProjects\guliMall>git push
Enumerating objects: 21, done.
Counting objects: 100% (21/21), done.
Delta compression using up to 16 threads
Compressing objects: 100% (8/8), done.
Writing objects: 100% (11/11), 785 bytes | 785.00 KiB/s, done.
Total 11 (delta 4), reused 0 (delta 0)
remote: Powered by GITEE.COM [1.1.5]
remote: Set trace flag b64264bf
To https://gitee.com/zhai_jiahao/guli.gite570078..b85a6f8  dev -> dev

解释:git push origin feature-20240828-test 命令已经成功执行,并且你的 feature-20240828-test 分支的更改已经被推送到了远程仓库
输出中的关键信息如下:

  • Total 0 (delta 0), reused 0 (delta 0):这表示在推送过程中,Git 没有传输任何新的数据对象(因为可能你之前已经推送过这些对象,或者这次推送没有新增任何文件)。delta
    指的是压缩后的差异数据,这里也是0,表示没有差异数据需要传输。
  • remote: Powered by GITEE.COM [1.1.5] 和 remote: Set trace flag 8040dbad:这些是 Gitee.com 服务器返回的信息,主要是表明服务器是由 Gitee.com
    提供支持的,并且设置了一个跟踪标志(可能是用于调试或日志记录)。
  • To https://gitee.com/zhai_jiahao/gulimall.git:这是你的远程仓库的 URL,表示你的推送目标是这个地址。
  • 556aaab…b85a6f8 feature-20240828-test -> feature-20240828-test:这表示从远程仓库的 feature-20240828-test 分支的 556aaab…
    b85a6f8 提交更新到了远程分支。这意味着远程仓库的 feature-20240828-test 分支现在与你的本地分支同步了。

注意:我这里没加上具体要推送到远程哪个仓库上,但是更好的习惯是加上远程仓库名称:像是这样 git push origin feature-20240828-test

命令8:分支合并

**目的:**我现在想要在dev开发分支开发的内容合并到test分支,因此 我在dev分支修改代码,增加了一行 ,来模拟自己在dev新增的代码,这个代码要合并到test分支上;
在这里插入图片描述
操作:
步骤1:在dev分支修改代码,然后commit到dev的本地仓库,然后push到远程,(其实这里只是需要commit到dev的本地仓库即可,因为本地执行merge命令是将本地仓库中dev分支开发的内容去合并到其他分支,所以这里严格来说只需要commit,无需push,但是一般的习惯,我们需要保证本地仓库dev分支代码和远程dev代码一致,所以一般commit之后,也会push到远程的),
步骤2:然后在切换到想要合并的目标分支 ,先切换到test分支后
步骤3:再使用git merge dev合并到test分支中,,再在控制台使用 下面命令,就可以将刚刚dev分支中修改的内容,合并到目前的test分支了;
步骤4:将合并到test中的内容推送到test的远程分支

D:\workspace\IdeaProjects\guliMall>git merge dev

**现象:**执行命令完毕,会提示有几行改变,下面图中是2行新增
1 file changed, 2 insertions(+)
在这里插入图片描述

好了,常用命令这就梳理的差不多了,当然也可以通过IDEA的ui页面直接操作也是可以的,原理步骤顺序都是类似,的,理解了上面的步骤,通过UI操作也恒轻松了~

如果在UI操作中遇见了问题,又改怎么解决呢 ?

可以看博客:【GIT】idea中实用的git操作,撤回commit,撤回push、暂存区使用

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 【管理型文档】软件需求管理过程(原件)
  • qemu 跨架构
  • linux系统中内存和缓冲简介
  • 小实战项目-第二章2.1-IIC协议讲解? 什么是软件IIC 什么是硬件IIC 有什么区别如何编写代码--这章节主要讲解软件IIC,下一章节讲解硬件IIC协议
  • 哈夫曼树例题
  • Matlab R2022b使用Camera Calibrator工具箱张正友标定法进行相机标定附带标定前后对比代码
  • 论文翻译:Multi-step Jailbreaking Privacy Attacks on ChatGPT
  • 设计模式(四)
  • 掌握 Rust 中的 YAML 魔法:Serde_yaml 使用指南
  • 【前端开发】国际化开发工具i18n的使用教程
  • MySQL 数据库深度解析:安装、语法与高级查询实战
  • BMC解决方案丨服务器故障诊断与预测平台方案设计与实现
  • 计算机毕业设计选题推荐-医疗就诊平台-在线医疗问诊系统-Java/Python项目实战
  • 【Android】根据URI获取文件扩展名或MimeType
  • Android SurfaceFlinger——共享内存读写流程(五十五)
  • Docker入门(二) - Dockerfile
  • If…else
  • Java 9 被无情抛弃,Java 8 直接升级到 Java 10!!
  • JS 面试题总结
  • Js基础知识(四) - js运行原理与机制
  • PHP 小技巧
  • Rancher-k8s加速安装文档
  • Redux系列x:源码分析
  • Solarized Scheme
  • SpringCloud集成分布式事务LCN (一)
  • vue-cli在webpack的配置文件探究
  • Zsh 开发指南(第十四篇 文件读写)
  • 规范化安全开发 KOA 手脚架
  • 基于遗传算法的优化问题求解
  • 讲清楚之javascript作用域
  • 全栈开发——Linux
  • 设计模式(12)迭代器模式(讲解+应用)
  • 新海诚画集[秒速5センチメートル:樱花抄·春]
  • (11)工业界推荐系统-小红书推荐场景及内部实践【粗排三塔模型】
  • (8)STL算法之替换
  • (c语言版)滑动窗口 给定一个字符串,只包含字母和数字,按要求找出字符串中的最长(连续)子串的长度
  • (翻译)terry crowley: 写给程序员
  • (论文阅读31/100)Stacked hourglass networks for human pose estimation
  • (十三)MipMap
  • (使用vite搭建vue3项目(vite + vue3 + vue router + pinia + element plus))
  • (顺序)容器的好伴侣 --- 容器适配器
  • (一)appium-desktop定位元素原理
  • (转载)深入super,看Python如何解决钻石继承难题
  • .NET 2.0中新增的一些TryGet,TryParse等方法
  • .net core Swagger 过滤部分Api
  • .NET/C# 利用 Walterlv.WeakEvents 高性能地定义和使用弱事件
  • .NET/C# 利用 Walterlv.WeakEvents 高性能地中转一个自定义的弱事件(可让任意 CLR 事件成为弱事件)
  • .net8.0与halcon编程环境构建
  • .net最好用的JSON类Newtonsoft.Json获取多级数据SelectToken
  • /bin、/sbin、/usr/bin、/usr/sbin
  • @angular/cli项目构建--Dynamic.Form
  • @kafkalistener消费不到消息_消息队列对战之RabbitMq 大战 kafka
  • @SpringBootConfiguration重复加载报错
  • [22]. 括号生成
  • [AHK] WinHttpRequest.5.1报错 0x80092004 找不到对象或属性