Git学习笔记(五)IDEA使用Git

news2025/1/13 9:50:26

        在前面几篇文章中,我们已经介绍了git的基础知识,知道了其主要作用是用来进行代码的版本管理;并且已经介绍了Git操作的常用命令。在日常的开发环境下,除了通过Bash命令行来操作Git之外,我们另外一种常用的操作方式则是直接通过开发工具来进行代码的版本管理。目前主流的开发工具如eclipse、IDEA等对于Git都提供了强大的支持,这里由于我日常使用的开发工具是IDEA,因此用IDEA进行举例。

IDEA配置Git

初始配置

        安装好IDEA后,如果Git安装在默认路径下,那么idea会自动找到git的位置,如果更改了Git的安 装位置则需要手动配置下Git的路径。选择File→Settings打开设置窗口,找到Version Control下的git选项:

如果在安装Git时都是选择的默认设置,这里一般会自动检测路径;如果没检测到,则手动选择Git安装目录下的git.exe文件。路径选择好后,可以点击右侧的测试按钮,如果显示了Git版本则表示配置成功了:

        接下来我们需要将一个正在开发的项目交给Git管理,首先需要做的事就是构建本地仓库,然后连接远程仓库

构建本地仓库

        通过Git Bash来构建本地仓库的方法我们在学习笔记(二)基本命令中介绍了,只需要在文件夹下打开Git Bash,然后执行git init命令即可,而在IDEA中打开的项目,我们可以通过简单的鼠标点击的方式来为项目构建本地仓库,具体操作方法如下图:

        经过上述步骤,其实我们本地仓库就已经构建好了,让我们来看看构建完成后界面有哪些变化:

可以看到IDEA的主界面变化主要有以下三点:

  1. 多出了一个文件vcs.xml:里面是一些版本控制的初始配置
  2. 文件名变成了红色:这代表着这些文件都处于Untracked状态(对状态不熟悉的同学去翻看Git学习笔记(一)基础概念)
  3. 右上角多出了三个图标:这也是使用IDEA进行Git操作最常用的三个按钮,后面会一一介绍他们的功能。

当发现右上角出现Git图标之后,意味着我们这个项目已经被Git管理,本地仓库构建完成。

连接远程仓库

        连接远程仓库之前,我们需要先构建一个远程仓库,具体步在Git学习笔记(四)远程仓库中有详细介绍,并且里面包含了如何通过Git Bash来让本地仓库与远程仓库建立连接的方法(git remote add [远程仓库名] [远程仓库地址]),这里就不过多赘述。

        建立好远程仓库之后,在IDEA中进行如下配置,就可以将刚刚构建的本地仓库与远程仓库建立连接:

        经过上述步骤,我们IDEA中的有关Git的相关配置就已经全部完成,接下来就可以直接在IDEA中使用Git来进行版本控制啦。

IDEA操作Git

最后,我们来讲讲IDEA中用来操作Git的几个常用按钮:

  1. 拉取按钮,表示从远程仓库拉取内容到本地仓库并合并到本地仓库的当前分支,相当于Git Bash中执行的pull命令。
  2. 提交按钮,表示将修改提交到本地仓库,相当于Git Bash中执行的add+commit命令。(注:IDEA中弱化了暂存区的存在,但实际上commit之前还是会先将修改add到暂存区)


    文件名颜色变绿,表示该文件已经提交到暂存区,但是还没有提交到仓库,处于staged状态,这时我们需要再点一次提交按钮。

    文件名变成白色,表示文件已提交,状态为commited。
  3. 推送按钮,表示将本地仓库的内容推送到远程仓库,相当于Git Bash中执行push命令。(注意:一般在点击推送按钮之前,需要先点击拉取按钮,在本地处理好分支冲突之后才能够推送到远程仓库)
  4. Git控制台,点击后可以打开Git控制台,在控制台中可以看到分支情况。
  5. 表示当前分支,对于分支的操作大部分在这里也可以进行:

    (注:这里的签出其实就是切换分支(checkout),汉化包的问题)

        以上几个按钮,就是我们日常在使用IDEA进行开发的过程中经常用到的Git管理按钮,通过这些按钮,我们能够方便的对代码进行版本控制,通过可视化的方式,以及简洁明了的操作方法,极大的减轻了我们使用Git时的负担,不再需要通过命令来对Git进行操作。不过个人建议Git bash的常用命令和一些基本概念还是需要掌握(可以看我之前的文章)。最后附上文件名颜色与文件状态的对应关系:

红色,未加入版本控制,git不管理,或者存在分支冲突
绿色,已加入版本控制,暂未提交
蓝色,已加入版本控制,已提交,有改动(提交后就变回白色)
白色,已加入版本控制,已提交,无改动
灰色:已加入版本控制,忽略的文件(.ignore)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1637508.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

探索APP内测分发的全过程(APP开发)

什么是APP内测分发探索APP内测分发的全过程? APP内测分发是在应用程序开发过程中探索APP内测分发的全过程,开发者将应用程序的测试版或预发布版分发给特定用户进行测试、反馈和评估的一种方式。这是一个非常重要的环节,可以有效地提高应用的…

MySQL —— 库的基本操作

一、数据库的增删查改 (1)创建 语句:create database db_name;(db_name是自定义的数据库名字) (2)删除 语句:drop database dp_name;(dp_name是要被删除的数据库的名字…

54.HarmonyOS鸿蒙系统 App(ArkTS)tcp socket套接字网络连接

54.HarmonyOS鸿蒙系统 App(ArkTS)tcp socket套接字网络连接 import socket from ohos.net.socket; import process from ohos.process; import wifiManager from ohos.wifiManager;import common from ohos.app.ability.common;let tcp socket.constructTCPSocketInstance();…

【17】JAVASE-集合专题【从零开始学JAVA】

Java零基础系列课程-JavaSE基础篇 Lecture:波哥 Java 是第一大编程语言和开发平台。它有助于企业降低成本、缩短开发周期、推动创新以及改善应用服务。如今全球有数百万开发人员运行着超过 51 亿个 Java 虚拟机,Java 仍是企业和开发人员的首选开发平台。…

【分治算法】【Python实现】循环赛日程表

文章目录 [toc]问题描述分治算法示例Python实现 无运动员数量约束循环赛日程表算法示例Python实现 个人主页:丷从心 系列专栏:分治算法 学习指南:Python学习指南 问题描述 设有 n 2 k n 2^{k} n2k个运动员要进行网球循环赛,设…

【高质量】2024五一数学建模C题保奖思路+代码(后续会更新)

你的点赞收藏是我后续更新的最大动力! 一定要点击文末的卡片,那是获取资料的入口! 你是否在寻找数学建模比赛的突破点? 作为经验丰富的数学建模团队,我们将为你带来2024 年五一数学建模(C题)…

文心一言 VS 讯飞星火 VS chatgpt (249)-- 算法导论18.2 2题

二、请解释在什么情况下(如果有的话),在调用 B-TREE-INSERT 的过程中,会执行冗余的 DISK-READ 或 DISK-WRITE 操作。(所谓冗余的 DISK-READ ,是指对已经在主存中的某页做 DISK-READ 。冗余的 DISK-WRITE 是…

SpringBoot中阿里OSS简单使用

官方文档:Java跨域设置实现跨域访问_对象存储(OSS)-阿里云帮助中心 1.pom中引入依赖 <dependency><groupId>com.aliyun.oss</groupId><artifactId>aliyun-sdk-oss</artifactId><version>3.15.1</version> </dependency> 如…

配置 Trunk,实现相同VLAN的跨交换机通信

1.实验环境 公司的员工人数已达到 100 人&#xff0c;其网络设备如图所示。现在的网络环境导致广播较多网速慢&#xff0c;并且也不安全。公司希望按照部门划分网络&#xff0c;并且能够保证一定的网络安全性。 其网络规划如下。 PC1和 PC3为财务部&#xff0c;属于VLAN 2&…

JavaFX创建桌面应用exe文件以及SceneBuilder使用讲解

文章目录 1 JavaFX1.1 引言1.2 简单使用1.2.1 搭建项目1.2.2 fxml文件1.2.3 生成exe文件 1.3 Idea中集成SceneBuilder1.4 注解讲解1.4.1 FXMLController1.4.2 FXML1.4.3 FXMLLoaderParameters1.4.4 FXMLProperty 1.5 SceneBuilder1.5.1 添加组件ControlsFX1.5.1.1页面展示 1.5.…

【c++】cpp类的继承

目录 &#xff08;1&#xff09;继承概念与语法 &#xff08;2&#xff09;派生类的访问控制 &#xff08;3&#xff09;继承中的构造和析构 1.类型兼容性原则 2.继承中的构造析构调用原则 3.继承与组合混搭下构造和析构调用原则 &#xff08;4&#xff09;同名成员(函数…

OI Wiki—递归 分治

//新生训练&#xff0c;搬运整理 递归 定义 递归&#xff08;英语&#xff1a;Recursion&#xff09;&#xff0c;在数学和计算机科学中是指在函数的定义中使用函数自身的方法&#xff0c;在计算机科学中还额外指一种通过重复将问题分解为同类的子问题而解决问题的方法。 引入…

Python语言零基础入门——模块

目录 一、模块的导入与使用 1.模块的导入 2.模块的使用 二、包的使用 1.包 2.包的使用 三、常见的标准库 1.random的运用举例 2.random小游戏 &#xff08;1&#xff09;石头剪刀布 &#xff08;2&#xff09;猜大小 3.re 4.time库的使用 5.turtle库的使用 6.so…

Zapier 与生成式 AI 的自动化(一)

原文&#xff1a;zh.annas-archive.org/md5/057fe0c351c5365f1188d1f44806abda 译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 前言 当组织处理手动和重复性任务时&#xff0c;生产力会遇到重大问题。Zapier 处于无代码运动的前沿&#xff0c;提供了一种先进的工具&a…

【C++】详解string类

目录 简介 框架 构造 全缺省构造函数 ​编辑 传对象构造函数 拷贝构造 析构函数 容量 size() capacity&#xff08;&#xff09; empty() clear() reserve() ​编辑 resize() 遍历 检引用符号"[ ]"的重载 迭代器 begin() end() rbegin() rend(…

【竞技宝】欧冠:拜仁2比2战平皇马,金玟哉状态低迷

拜仁在欧冠半决赛首回合较量中坐镇主场跟皇马相遇,这场比赛踢得非常激烈好看。拜仁并没有在主场苟着踢,而是跟皇马打对攻,让球迷大呼过瘾。最终,拜仁与皇马激战90分钟后,以2比2比分战平。对于这样的比赛结果,大部分拜仁球迷都觉得不服气。因为,他们认为自家中卫金玟哉太差,如果…

3D建模在游戏行业的演变和影响

多年来&#xff0c;游戏行业经历了显着的转变&#xff0c;这主要是由技术进步推动的。 深刻影响现代游戏的关键创新之一是 3D 建模领域。 从像素化精灵时代到我们今天探索的错综复杂的游戏世界&#xff0c;3D 建模已成为游戏开发不可或缺的基石。 本文讨论 3D 建模在游戏行业中…

智能健康管理子卡(ChMC/IPMC)模块,支持IPMI2.0标准通信协议,0Kbps可配置,可通过IPMI命令控制其他刀片开关电,具备故障上报、开机自检

是一款BMC子卡&#xff0c;该子卡输出1路千兆网络接口与千兆交换芯片相连,对外输出1路百兆调试网络接口&#xff0c;对外输出2路8路&#xff08;可选&#xff09;IPMB&#xff08;I2C&#xff09;接口并做隔离处理&#xff08;I2C BUFFER&#xff09;&#xff0c;支持IPMI2.0标…

【代码随想录——链表】

1.链表 什么是链表&#xff0c;链表是一种通过指针串联在一起的线性结构&#xff0c;每一个节点由两部分组成&#xff0c;一个是数据域一个是指针域&#xff08;存放指向下一个节点的指针&#xff09;&#xff0c;最后一个节点的指针域指向null&#xff08;空指针的意思&#…

rust疑难杂症

rust疑难杂症解决 边碰到边记录&#xff0c;后续可能会逐步增加&#xff0c;备查 cargo build时碰到 Blocking waiting for file lock on package cache 原因是Cargo 无法获取对包缓存的文件锁&#xff0c; 有时vscode中项目比较多&#xff0c;如果其中某些库应用有问题&…