Git的安装与使用+Git在IDEA中的使用

news2024/11/23 2:18:47

文章目录

  • 一、Git概述
    • 1、版本控制器的方式
    • 2、Git的工作流程图
  • 二、Git的安装与常用命令
    • 1、Git环境安装
    • 2、Git环境基本配置
    • 3、获取本地仓库
    • 4、基础操作指令
  • 三、分支
    • 1、常用指令
    • 2、解决合并冲突
  • 四、Git远程仓库
    • 1、创建远程仓库
    • 2、远程操作仓库
    • 3、冲突处理
  • 四、IDEA中使用Git
    • 1、在IDEA中配置Git
    • 2、在IDEA中操作Git
    • 3、一些其他操作入口
    • 4、IDEA集成GitBash作为Terminal
    • 5、代码拉取的常见场景

一、Git概述

开发中,代码备份、代码还原回滚、追溯、协同开发等场景必不可少,由此,版本控制工具诞生。

1、版本控制器的方式

  • 集中式版本控制工具
  • 分布式版本控制工具

集中式版本控制工具,版本库是集中存放在中央服务器的,team里每个人工作时从中央服务器下载代码,是必须联网才能工作,局域网或互联网。个人修改后然后提交到中央版本库。代表是:SVN和CVS。
在这里插入图片描述

分布式版本控制系统没有“中央服务器”,每个人的电脑上都是一个完整的版本库,这样工作的时候,无需要联网了,因为版本库就在你自己的电脑上。多人协作只需要各自的修改推送给对方,就能互相看到对方的修改了。代表:Git。
在这里插入图片描述

注意:

Git是分布式的,不需要有中心服务器,我们使用Git并且有个中心服务器,仅仅是为了方便交换大家的修改,但是这个服务器的地位和我们每个人的PC是一样的。我们可以把它当做一个开发者的pc就可以,它就是为了大家代码容易交流不关机用的。没有它大家一样可以工作,只不过“交换”修改不方便而已。

2、Git的工作流程图

在这里插入图片描述

  • clone(克隆): 从远程仓库中克隆代码到本地仓库
  • checkout (检出):从本地仓库中检出一个仓库分支到工作区然后进行修订
  • add(添加): 在提交前先将代码提交到暂存区
  • commit(提交): 提交到本地仓库。本地仓库中保存修改的各个历史版本
  • fetch (抓取) : 从远程库,抓取到本地仓库,不进行任何的合并动作,一般操作比较少
  • pull (拉取) : 从远程库拉到本地库,自动进行合并(merge),然后放到到工作区,相当于fetch+merge
  • push(推送) : 修改完成后,需要和团队成员共享代码时,将代码推送到远程仓库

二、Git的安装与常用命令

1、Git环境安装

  • 下载地址: https://git-scm.com/download
    在这里插入图片描述
  • 下载后得到Git-version.exe文件
    在这里插入图片描述
  • 双击exe文件,安装Git,在桌面右键能看到两个Git的菜单即安装成功
    在这里插入图片描述

2、Git环境基本配置

打卡Git Bash配置用户信息

# 设置用户名
git config --global user.name "llg"
git config --global user.email "llg@163.com"
# 查看配置信息
git config --global user.name
git config --global user.email

对于参数长但又常用的指令,使用别名:

# 在用户目录下新建.bashrc文件
touch ~/.bashrc

# Vi编辑文件,输入下面内容

#用于输出git提交日志
alias git-log='git log --pretty=oneline --all --graph --abbrev-commit'
#用于输出当前目录所有文件及基本信息
alias ll='ls -al

Git Bash乱码时,先执行

git config --global core.quotepath false

再在${git_home}/etc/bash.bashrc 文件最后加入下面两行

export LANG="zh_CN.UTF-8"
export LC_ALL="zh_CN.UTF-8"

3、获取本地仓库

  • 在电脑的任意位置创建一个空目录(例如D:\Git\my-git)作为本地Git仓库
    在这里插入图片描述

  • 进入这个目录中,点击右键打开Git bash窗口

  • 执行命令git init初始化当前目录为一个git仓库
    在这里插入图片描述

  • 创建成功后可在文件夹下看到隐藏的.git目录

4、基础操作指令

在这里插入图片描述
对工作目录中的代码文件进行增删改,使用指令控制其状态:

# 查看的修改的状态(暂存区、工作区)
git status 
# 工作区 --> 暂存区
git add 单个文件名
# 将所有修改加入暂存区
git add . 
# 暂存区 --> 本地仓库
# 提交暂存区内容到本地仓库的当前分支
git commit -m '注释内容'
# 查看提交代码文件的日志记录
git log [option]
# 参数
 --all 显示所有分支
 --pretty=oneline 将提交信息显示为一行
 --abbrev-commit 使得输出的commitId更简短
 --graph 以图的形式显示
# 版本回滚
# 提交号通过git log查看
git reset --hard commitID
# 查看已经删除的提交记录号
git reflog
# 添加文件至忽略列表
# 有些文件无需纳入Git 的管理,也不希望它们总出现在未跟踪文件列表,如日志文件,或者编译过程中创建的临时文件
# 在工作目录,创建gitignore 的文件(文件名称固定)
touch gitignore
# gitignore 的文件示例
# no .a files
*.a
# but do track lib.a, even though you're ignoring .a files above
!lib.a
# only ignore the TODO file in the current directory, not subdir/TODO
/TODO
# ignore all files in the build/ directory
build/
# ignore doc/notes.txt, but not doc/server/arch.txt
doc/*.txt
# ignore all .pdf files in the doc/ directory
doc/**/*.pdf

三、分支

使用分支来把你的工作从开发主线上分离开来进行重大的Bug修改、开发新的功能,以免影响开发主线。

1、常用指令

  • 查看本地分支
# git log中head指向谁,谁就是当前分支
git branch
  • 创建本地分支
git branch 分支名
  • 切换分支
git checkout 分支名
  • 直接切换到一个不存在的分支(创建并切换)
git checkout -b 分支名
  • 合并分支(A分支合并到master分支,先切换到master分支)
git merge 分支名称
# 当A分支刚好比master分支多几个文件,此时合并是快进模式fast-forward
# 快进模式下git的版本图形中没有拱形
  • 删除分支(不能删除当前分支,只能删除其他分支)
git branch -d b1  删除分支时,需要做各种检查
git branch -D b1 不做任何检查,强制删除
# 一般来说,当你要删除的分支,有代码没有合并到主分支时,会有提示,只能用-D

2、解决合并冲突

当两个人同时修改了同一行代码而结果不同时,合并代码会发生冲突。此时需要手动处理冲突:

  • 处理文件中冲突的地方
  • 将解决完冲突的文件加入暂存区(add)
  • 提交到仓库(commit)

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
关于分支,工作中常见的有:

  • master 分支:线上分支,主分支,中小规模项目作为线上运行的应用对应的分支
  • develop 分支:开发分支,是从master创建的分支,一般作为开发部门的主要开发分支,阶段开发完成后,需要是合并到master分支,准备上线
  • feature-xxxx分支:需求分支,从develop创建的分支,分支上的研发任务完成后合并到develop分支
  • hotfix-xxxx分支:从master派生的分支,一般作为线上bug修复使用,修复完成后需要合并到master、test、develop分支
  • test分支:用于代码测试
  • pre分支:预上线分支

在这里插入图片描述

四、Git远程仓库

整理完本地仓库,接下来是远程仓库。关于Git远程仓库,互联网上提供的一些代码托管服务来实现,其中比较常用的有GitHub、码云、GitLab:

  • GitHub( 地址:https://github.com/ )是一个面向开源及私有软件项目的托管平台,只支持Git 作为唯一的版本库格式进行托管,故名GitHub。(国外服务器)
  • 码云(地址: https://gitee.com/ )是国内的一个代码托管平台,由于服务器在国内,所以相比于GitHub,码云速度会更快
  • GitLab (地址: https://about.gitlab.com/ )是一个用于仓库管理系统的开源项目,使用Git作为代码管理工具,并在此基础上搭建起来的web服务,一般用于在企业、学校等内部网络搭建git私服

1、创建远程仓库

下面使用码云做为远程仓库:

  • 注册后创建仓库

在这里插入图片描述

  • 这里就是远程仓库的地址

在这里插入图片描述

  • 配置SSH公钥(也可以选择每次输入账户密码)
# Git Bash中执行以下指令,rsa是一种算法
# 不断回车,生成公钥,公钥已经存在,则自动覆盖
ssh-keygen -t rsa
# 查看公钥并复制到gitee中
cat ~/.ssh/id_rsa.pub

在这里插入图片描述

# 查看是否配置成功
ssh -T git@gitee.com

2、远程操作仓库

  • 添加远程仓库
git remote add <远端名称> <仓库路径>
# 远端名称,默认约定常用是origin
  • 查看远程仓库
git remote
# 返回结果origin
  • 代码推送到远程仓库
git push [-f] [--set-upstream] [远端名称 [本地分支名][:远端分支名] ]
参数:
 - -f:本地和远程仓库冲突时,以本地为准,强制覆盖(有风险)
 - --set-upstream 推送到远端的同时并且建立起和远端分支的关联关系
git push --set-upstream origin master:master
# 当前分支已经和远端分支关联,则可以省略分支名和远端名
# 有了对应关系,下次直接:
git push

在这里插入图片描述

  • 查看本地分支与远程分支的关系
git branch -vv

在这里插入图片描述

  • 从远程仓库克隆代码到本地
git clone <仓库路径> [本地目录]
# 本地目录可以省略,默认拿路径最后的名字

在这里插入图片描述

  • 抓取:将仓库里的更新都抓取到本地,不会进行合并
git fetch [remote name] [branch name]
# 如果不指定远端名称和分支名,则抓取所有分支
  • 拉取:将远端仓库的修改拉到本地并自动进行合并,等同于fetch+merge
git pull [remote name] [branch name]
# 果不指定远端名称和分支名,则抓取所有并更新当前分支

3、冲突处理

A、B用户修改了同一个文件,且修改了同一行位置的代码。A用户在本地修改代码后优先推送到远程仓库,此时B用户在本地修订代码,提交到本地仓库后,也需要推送到远程仓库,此时B用户晚于A用户,故需要先拉取远程仓库的提交,经过合并后才能推送到远端分支。

在这里插入图片描述
解决步骤:

  • 先拉取最新代码git pull
  • 选择保留的代码版本,解决冲突
  • git add . + git commit -m 提交到本地
  • git push推送到远程仓库

四、IDEA中使用Git

1、在IDEA中配置Git

File→Settings打开设置窗口,找到Version Control下的git选项:
在这里插入图片描述

点击Test,显示你安装的Git的版本,即配置成功。

2、在IDEA中操作Git

  • 初始化本地仓库

在这里插入图片描述

  • 设置远程仓库

在这里插入图片描述

  • 点击提交代码commit到本地
    在这里插入图片描述
  • 将代码推送到远程仓库

在这里插入图片描述

  • 克隆远程仓库代码到本地
    在这里插入图片描述
  • 从某个分支起创建新分支
    在这里插入图片描述
  • 从某个提交点起创建新分支
    在这里插入图片描述
  • 切换分支与删除分支
    在这里插入图片描述

3、一些其他操作入口

Git的快捷操作按钮:

在这里插入图片描述
也可以在这里进行操作:

在这里插入图片描述

4、IDEA集成GitBash作为Terminal

在这里插入图片描述
在这里插入图片描述

5、代码拉取的常见场景

基于本项目创建本地仓库;创建远程仓库,推送项目到远程仓库。
在这里插入图片描述
组员从远程仓库克隆项目到idea中:

在这里插入图片描述
组员A修改工作区,提交到本地仓库,再推送到远程仓库。组员B可以直接从远程仓库获取最新的代码:

在这里插入图片描述
组员A和组员B修改了同一个文件的同一行,提交到本地没有问题,但是推送到远程仓库时,后一个推送操作就会失败。此时需要先获取远程仓库的代码到本地仓库,编辑冲突敲定要保留的版本,提交并推送代码:

在这里插入图片描述
最后,切换分支前先提交本地的修改,以防止代码丢失。

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

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

相关文章

数据结构——二叉树

二叉树 1 二叉树的种类 1.1 满二叉树 节点数量为 2^k - 1 (k是树的深度&#xff0c;底层的叶子节点都是满的&#xff09; 1.2 完全二叉树 完全二叉树是指除了下面一层外&#xff0c;其余层的节点都是满的&#xff1b; 且最下面一层的叶子节点是从左到右连续的。 下面这个…

pci总线协议学习笔记——PCI总线基本概念

1、pci总线概述 (1)PCI&#xff0c;外设组件互连标准(Peripheral Component Interconnection)&#xff0c;是一种由英特尔&#xff08;Intel&#xff09;公司1991年推出的用于定义局部总线的标准; (2)最早提出的PCI总线工作在33MHz频率之下&#xff0c;传输带宽达到133MB/s(33M…

【LeetCode】236. 二叉树的最近公共祖先

1.问题 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为&#xff1a;“对于有根树 T 的两个节点 p、q&#xff0c;最近公共祖先表示为一个节点 x&#xff0c;满足 x 是 p、q 的祖先且 x 的深度尽可能大&#xff08;一个节点也可以是…

1992-2022年31省GDP、第一产业增加值、第二产业增加值 第三产业增加值

1992-2022年31省GDP、第一产业增加值、第二产业增加值 第三产业增加值 1、时间&#xff1a;1992-2022年 2、范围&#xff1a;包括31省 3、指标&#xff1a;省GDP、省第一产业增加值、省第二产业增加值、省第三产业增加值 4、缺失情况说明&#xff1a;无缺失 5、来源&#…

【python知识】__init__.py的来龙去脉

一、说明 我们常见__init__.py文件&#xff0c;但说不清楚它的用途&#xff0c;在本文&#xff0c;我将首先把它的来龙去脉说清楚&#xff0c;然后告诉大家&#xff0c;如何编制python工程&#xff0c;培养全局的编程格局。 二、包-模块-函数结构 在Python工程里&#xff0c;当…

playwright连接已有浏览器操作

文章目录 playwright连接已有浏览器操作前置准备打开本地已有缓存的Chrome&#xff08;理解&#xff09;指定端口打开浏览器连接指定端口已启动浏览器&#xff08;推荐&#xff09; playwright连接已有浏览器操作 前置准备 pip install playwright # 安装playwright的python…

红黑树数据结构

现在JAVASE中HashMap中底层源码是由数组链表红黑树进行设计的&#xff0c;然后很多地方也是用到红黑树&#xff0c;这里单独对红黑树数据结构进行简单的介绍。 目录 红黑树概念 红黑树的性质 自平衡规则 代码 红黑树概念 红黑树&#xff0c;是一种二叉搜索树&#xff0c;…

linux常用命令大全(保姆及入门)

linux常用命令大全 一、文件处理命令1、目录处理命令&#xff1a;ls2、目录处理命令2.1 mkdir2.2 pwd2.3 rmdir2.4 cp2.5 mv2.6 rm 3.文件处理命令3.1 touch3.2 cat3.3 tac3.4 more3.5 less3.6 head3.7 tail 4.链接命令4.1 ln 二、权限管理命令2.1 chmod2.2 chown2.3 chgrp 2.4…

VRPTW:新雀优化算法NOA求解带时间窗的车辆路径问题

一、新雀优化算法NOA求解带时间窗的车辆路径问题 1.1VRPTW模型如下&#xff1a; 带时间窗的车辆路径问题(Vehicle Routing Problem with Time Windows, VRPTW) 1.2新雀优化算法NOA求解VRPTW close all clear clc SearchAgents_no30; % 种群大小 Function_nameF1; Max_ite…

准备“开黑”,电脑却“告退”?游戏闪退的解决方法

游戏玩家近期可能会发现&#xff0c;不少大作陆陆续续登录PC市场&#xff0c;比如《死亡岛 2》、《无畏契约》等。但也有不少游戏用户会发现&#xff0c;电脑玩游戏时容易出现闪退的情况。特别是在进行高负荷运算的时候&#xff0c;有一些游戏更为容易出现这种情况&#xff0c;…

[架构之路-176]-《软考-系统分析师》-17-嵌入式系统分析与设计 -1- 实时性(任务切换时间、中断延迟时间、中断响应时间)、可靠性、功耗、体积、成本

目录 前言&#xff1a; 1 7 . 1 嵌 入 式 系 统 概 述 1 . 嵌入式系统的特点 (1) 系统专用性强。 (2) 系统实时性强。 (3) 软硬件依赖性强 (4) 处理器专用。 ( 5 ) 多种技术紧密结合。 (6) 系统透明性。 (7) 系统资源受限。 2 . 嵌入式系统的组成 1 7 . 3 嵌入式实…

拷贝构造函数和赋值重载函数详解

1.拷贝构造函数 1.1拷贝构造函数的概念 拷贝构造函数&#xff1a;只有单个形参&#xff0c;该形参是对本类类型对象的引用(一般常用const修饰)&#xff0c;在用已存在的类类型对象创建新对象时由编译器自动调用。拷贝构造函数也是特殊的成员函数&#xff0c;其特征如下&#…

Golang每日一练(leetDay0051)

目录 151. 颠倒字符串中的单词 Reverse Words In A String &#x1f31f;&#x1f31f; 152. 乘积最大子数组 Maximum Product Sub-Array &#x1f31f;&#x1f31f; &#x1f31f; 每日一练刷题专栏 &#x1f31f; Golang每日一练 专栏 Python每日一练 专栏 C/C每日一…

【分布式】CAP原则和BASE理论

CAP原则概述 CConsistency一致性AAvailability可用性PPartition tolerance分区容错性 1998年&#xff0c;加州大学的计算机科学家Eric Brewer提出&#xff0c;分布式系统有三个指标 一致性&#xff08;C&#xff09;&#xff1a;在分布式系统中的所有数据备份&#xff0c;在同…

TiDB实战篇-基于索引的SQL优化

简介 TiDB实战篇-基于索引的SQL优化。 Online DDL 允许直接在线执行ddl操作&#xff0c;不会锁表&#xff0c;但是执行多个ddl的时候会要排队。 原理 控制创建索引的速度 查看影响 标红的是加了多少行索引。 添加索引的线上的影响&#xff08;读写频繁&#xff09; 只读场…

Linux程序设计之IP地址转换

1.通常&#xff0c;人们习惯于使用可读性好的字符串来表示IP的地址&#xff0c;但是&#xff0c;在实际的使用过程中&#xff0c;需要使用的IP地址应该为无符号的整数(在计算机中存储时是对应的二进制&#xff0c;只有二进制计算机才能识别&#xff0c;即0、1)。已经封装好的函…

windows开机不自动挂载磁盘的方法

本人的电脑系统为win11 写作时间20230430 开机不挂载某块磁盘的理由 1.本人电脑上有个仓库盘是机械硬盘&#xff0c;并不是每次开机都要用到&#xff0c;开机不挂载也许有利于增加数据盘的寿命 2.挂载了数据盘&#xff0c;有时候打开文件页面会比较慢&#xff0c;不够丝滑 …

MATLAB绘制汽车理论的仿真图片

这里写自定义目录标题 仿真绘图内容发动机最优曲线最优燃油消耗率曲线最优效率曲线工作时间/能量消耗的分布 传统车动力性分析绘制三&#xff08;或多个&#xff09;y坐标轴函数统计数据分布情况函数 仿真绘图内容 从传统车到新能源混合动力车型的不同绘制。 发动机最优曲线 …

排序算法 - 选择排序

文章目录 选择排序介绍选择排序实现选择排序的时间复杂度和稳定性选择排序时间复杂度选择排序稳定性 代码实现核心&总结 每日一道算法&#xff0c;提高脑力。第四天&#xff0c;选择排序。 选择排序介绍 它的基本思想是: 首先在未排序的数列中找到最小(or最大)元素&#…

Vue3超详细的ref()用法,看这一篇就够了

ref()接受一个内部值&#xff0c;返回一个响应式的、可更改的 ref 对象&#xff0c;此对象只有一个指向其内部值的属性 .value。 ref() 将传入参数的值包装为一个带 .value 属性的 ref 对象。 1、ref 对象是可更改的&#xff0c;即可以为 .value 赋予新的值 举例&#xff1a; c…