Git学习资料

Git概述

	Git 是一个免费的、开源的分布式版本控制系统,可以快速高效地处理从小型到大型的各种项目。
	Git 易于学习,占地面积小,性能极快。 它具有廉价的本地库,方便的暂存区域和多个工作 流分支等特性。其性能优于 Subversion、CVS、Perforce 和 ClearCase 等版本控制工具。

1 何为版本控制

	版本控制是一种记录文件内容变化,以便将来查阅特定版本修订情况的系统。
	版本控制其实最重要的是可以记录文件修改历史记录,从而让用户能够查看历史版本,方便版本切换。

2 为什么需要版本控制

个人开发过渡到团队协作

在这里插入图片描述

3 版本控制工具

3.1 集中版本控制工具

	CVS、SVN(Subversion)、VSS……
	集中化的版本控制系统诸如 CVS、SVN 等,都有一个单一的集中管理的服务器,保存所有文件的修订版本,而协同工作的人们都通过客户端连到这台服务器,取出最新的文件或者提交更新。多年以来,这已成为版本控制系统的标准做法。
	这种做法带来了许多好处,每个人都可以在一定程度上看到项目中的其他人正在做些什么。而管理员也可以轻松掌控每个开发者的权限,并且管理一个集中化的版本控制系统,要远比在各个客户端上维护本地数据库来得轻松容易。
	事分两面,有好有坏。这么做显而易见的缺点是中央服务器的单点故障。如果服务器宕机一小时,那么在这一小时内,谁都无法提交更新,也就无法协同工作

在这里插入图片描述

3.2 分布式版本控制工具

	Git、Mercurial、Bazaar、Darcs……
	像 Git 这种分布式版本控制工具,客户端提取的不是最新版本的文件快照,而是把代码仓库完整地镜像下来(本地库)。这样任何一处协同工作用的文件发生故障,事后都可以用其他客户端的本地仓库进行恢复。因为每个客户端的每一次文件提取操作,实际上都是一次对整个文件仓库的完整备份。
	分布式的版本控制系统出现之后,解决了集中式版本控制系统的缺陷:
	1. 服务器断网的情况下也可以进行开发(因为版本控制是在本地进行的)
	2. 每个客户端保存的也都是整个完整的项目(包含历史记录,更加安全)

在这里插入图片描述

4 Git历史

在这里插入图片描述

5 工作机制

在这里插入图片描述

6 Git 和代码托管中心

代码托管中心是基于网络服务器的远程代码仓库,一般我们简单称为远程库。

6.1 局域网: GitLab

6.2 互联网:GitHub(外网) 、Gitee 码云(国内网站)

Git安装

Git常用命令

命令名称作用
git config --global user.name 用户名设置用户签名
git config --global user.email 邮箱设置用户签名
**git init初始化本地库
**git status查看本地库状态
**git add 文件名添加到暂存区
**git commit -m “日志信息” 文件名提交到本地库
**git reflog查看历史记录
**git reset --hard 版本号版本穿梭

1 设置用户签名

1.1 基本语法

 git config --global user.name 用户名 
 git config --global user.email 邮箱

1.2 案例实操

在这里插入图片描述

2 初始化本地库

2.1 基本语法

git init

2.2 案例实操

在这里插入图片描述

2.3 结果查看

在这里插入图片描述

3 查看本地库的状态

3.1 首次查看(工作区没有任何文件)

3.2 新增文件(hello.txt)

3.3 再次查看(检测到未追踪的文件)

4 添加暂存区

4.1 将工作区的文件添加到暂存区

4.2 删除暂存区文件

git rm --cached 文件名

4.3 查看状态

5 提交本地库

5.1 将暂存区的文件提交到本地库

5.2 查看状态(没有文件需要提交)

6 修改文件(hello.txt)

6.1 查看状态

6.2 将修改的文件再次添加到暂存区

6.3 查看状态

7 历史版本

7.1 查看历史版本

7.2 版本穿梭

Git分支操作

在这里插入图片描述

1 什么是分支

在版本控制过程中,同时推进多个任务,为每个任务,我们就可以创建每个任务的单独分支。使用分支意味着程序员可以把自己的工作从开发主线上分离开来,开发自己分支的时候,不会影响主线分支的运行。对于初学者而言,分支可以简单理解为副本,一个分支就是一个单独的副本。(分支底层其实也是指针的引用)

2 分支的好处

同时并行推进多个功能开发,提高开发效率。各个分支在开发过程中,如果某一个分支开发失败,不会对其他分支有任何影响。失败的分支删除重新开始即可。

3 分支的操作

3.1 查看分支

3.2 创建分支

3.3 修改分支

3.4 切换分支

3.5 合并分支

3.6 产生冲突

3.7 解决冲突

4 创建分支和切换分支图解

在这里插入图片描述

master、hot-fix 其实都是指向具体版本记录的指针。当前所在的分支,其实是由 HEAD决定的。所以创建分支的本质就是多创建一个指针。HEAD 如果指向 master,那么我们现在就在 master 分支上。HEAD 如果执行 hotfix,那么我们现在就在 hotfix 分支上

Git团队协作机制

1 团队内协作

在这里插入图片描述

2 跨团队协作

在这里插入图片描述

GitHub操作

1 创建远程仓库

在这里插入图片描述

在这里插入图片描述

2 远程仓库操作

2.1 创建远程仓库别名

2.2 推送本地分支到远程仓库

2.3 克隆远程仓库到本地

注意:克隆代码不需要登录账号

2.4 邀请加入团队

2.5 拉取远程库操作

3 跨团队协作

4 SSH免密登录

IDEA集成Git

1 配置Git忽略文件

问题 1:为什么要忽略他们?

答:与项目的实际功能无关,不参与服务器上部署运行。把它们忽略掉能够屏蔽 IDE 工具之 间的差异。

问题 2:怎么忽略?

答:①创建忽略规则文件 xxxx.ignore(前缀名随便起,建议是 git.ignore) 这个文件的存放位置原则上在哪里都可以,为了便于让~/.gitconfig 文件引用,建议也放在用 户家目录下

git.ignore 文件模版内容如下:

# Compiled class file
*.class

# Log file
*.log
# BlueJ files
*.ctxt
# Mobile Tools for Java (J2ME)
.mtj.tmp/
# Package Files #
*.jar
*.war
*.nar
*.ear
*.zip
*.tar.gz
*.rar
# virtual machine crash logs, see 
http://www.java.com/en/download/help/error_hotspot.xml
hs_err_pid*
.classpath
.project
.settings
target
.idea
*.iml

②在.gitconfig 文件中引用忽略配置文件(此文件在 Windows 的家目录中)

[user]
name = Layne
email = Layne@atguigu.com
[core]
excludesfile = C:/Users/asus/git.ignore
注意:这里要使用“正斜线(/)”,不要使用“反斜线(\)

2 定位Git程序

在这里插入图片描述

3 初始化本地库

在这里插入图片描述

在这里插入图片描述

4 添加到暂存区

5 提交到本地库

6 切换版本

7 创建分支

8 切换分支

9 合并分支

10 解决冲突

IDEA集成GitHub

1 设置GitHub账号

2 分享工程到GitHub

3 push推送本地库到远程库

4 pull拉取远程库到本地库

5 clone克隆远程库到本地

国内代码托管中心-Gitee(码云)

4 添加到暂存区

5 提交到本地库

6 切换版本

7 创建分支

8 切换分支

9 合并分支

10 解决冲突

IDEA集成GitHub

1 设置GitHub账号

2 分享工程到GitHub

3 push推送本地库到远程库

4 pull拉取远程库到本地库

5 clone克隆远程库到本地

国内代码托管中心-Gitee(码云)

自建代码托管平台-GitLab

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

似梦的苏烟

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值