【Linux】git的使用
创始人
2024-05-22 11:25:31
0

文章目录

  • 🎪 Linux下git的使用
    • 🚀1.git三板斧
      • ⭐1.1 准备工作
      • ⭐1.2 git add
      • ⭐1.3 git commit
      • ⭐1.4 git push
      • ⭐1.5 筛选提交
    • 🚀2.git分区
      • ⭐2.1 工作区
      • ⭐2.2 暂存区
      • ⭐2.3 版本区
    • 🚀3.git分支管理
      • ⭐3.1 分支创建与切换
      • ⭐3.2 分支合并
      • ⭐3.3 标签和模块管理


🎪 Linux下git的使用

Git属于分散型版本管理系统,是为版本管理而设计的软件。Linux的创始人Linus Torvalds在2005年开发了Git的原型程序。当时,由于在Linux内核开发中使用的既有版本管理系统的开发方许可证发生了变更,为了更换新的版本管理系统,Torvalds开发了Git。很多优质博主在从Subversion改用Git时,也对其强大的功能和性能感到震惊。Git功能多到夸张,让人觉得至今都没能彻底掌握它。同时,它大幅削减了程序员花在版本管理系统上的时间,现在如果没有Git,软件开发恐怕会是一件非常痛苦的事情。

在发布之初,Git由于其艰涩难懂,只有部分黑客愿意使用。但随着众多开发者的共同努力,现在它已被全世界的程序员们所采用。
在这里插入图片描述

🚀1.git三板斧

我们的git提交远端仓库需要三步,也就是我们常说的三板斧。

⭐1.1 准备工作

我们必须先把远端仓库的http地址克隆到本地才能进行三板斧提交,我们以gitee为例,仓库地址如下:
在这里插入图片描述
这个地址就是我们远端仓库的地址,我们需要把它克隆到本地。首先我们需要在Linux中找到我们需要存放本地仓库的目录,在该目录下:

命令:git clone URL(刚刚复制的地址)
功能:将远端克隆到本地

在这里插入图片描述
下载到本地仓库后,commit文件需要配置user.nameuser.email两个属性
键入以下命令:

git config --global user.name '用户名'
git config --global user.email '电子邮件'

准备工作已完成。

⭐1.2 git add

将我们需要提交的文件拷贝到该本地仓库(目录)下:

命令:git add
功能:将工作区(本地仓库)文件提交到暂存区

⭐1.3 git commit

我们可以把这步操作称为同步

命令:git commit -m '提交日志'
功能:将暂存区的文件提交到版本区

我们的提交日志一定不要乱写,一定要写清楚这份文件的属性。因为不仅这方便我们以后查看,更重要的是我们以后版本回退要看提交日志,不然自己都不知道该回退到哪个版本

⭐1.4 git push

命令:git push
功能:将版本区的文件同步到远端服务器

此时我们需要在Linux下填写gitee远端仓库的用户名和密码,方可同步.

也可以配置免用户名密码同步:Linux下免用户名密码提交

⭐1.5 筛选提交

我们有一些配置文件无需提交至远端仓库(例如java文件的IDE配置文件),我们可以修改本地仓库的.gitignore文件来实现筛选提交

# 所有类型为txt的文件
*.txt 
# 不忽略a.txt
!a.txt
# b目录下所有文件 
b/
# b目录下所有层级下的c.txt文件     
b/**/c.txt  

🚀2.git分区

下面是一个文件的几种状态
在这里插入图片描述

⭐2.1 工作区

当一个文件创建后就在工作区,也就是我们的工作目录,我们可以使用命令:git add ‘文件名/目录名’ 将工作区文件提交到暂存区

⭐2.2 暂存区

我们可以用git commit -m '提交日志’将暂存区的文件,除此之外,还有如下命令:

  • 清除暂存区文件
  • git rm --cashed test.c:清除暂存区中的test.c文件
  • git rm -f a.txt:强制删除。
  • 将暂存区中test.c文件替换工作区中test.c文件
  • git checkout -- test.c

这个操作很危险,会清除工作区中未添加改动

  • 版本回退
  • git reset HEAD test.c:将暂存区中test.c文件回退到上一次提交后版本,不影响工作区
  • git reset --soft HEAD^:回退到上次commit的版本
  • git reset --hard HEAD^:重置版本库所有文件到最后一次commit(回退版本,不能回退指定文件,工作区文件也回退,清除暂存区)。
  • git reset --hard 04ae:重置版本库所有文件到指定commit。

⭐2.3 版本区

  • 查看历史提交记录
  • git log
  • 比较不同分区文件
  • git diff a.txt:比较暂存区和工作区a.txt文件的区别
  • git diff HEAD a.txt:比较最新commit和工作区a.txt文件的区别
  • git diff --cached a.txt:比较最新commit和暂存区a.txt文件的区别

🚀3.git分支管理

使用分支可以让我们每个人独立于主线之外开发,互不影响。假设我们有一个团队,这个团队有多个成员,每个成员都可以算是一个分支,共同完成主线master的开发,那么这其中就牵涉到了分支的创建与切换、删除,分支的合并,分支的标签管理等。

⭐3.1 分支创建与切换

  • 创建分支
  • git branch:查看所有分支
  • git branch test1:创建test1分支
  • git branch -m test1 test2:修改test1分支的名称为test2
  • 切换分支
  • git checkout test1:切换到test1分支
  • git checkout -b test1:创建test1分支并切换到test1分支
  • 删除分支
  • git branch -d test1:删除test1分支,如果test1分支有提交没有被合并,不能删除,可以强制删除或进行合并
  • git branch -D test1:删除test1分支,强制删除

⭐3.2 分支合并

分支合并的本质是将协作的的文件合为一个新文件,git的会将所有commit串成一条线,每个commit都有一个或多个parent指针,指向上次commit的指针,而该分支(例如master)的master指针则会指向该分支最新提交的commit

合并过程:

  • 创建master分支,头指针Head指向该master分支,master分支指针指向最新commit记录
    在这里插入图片描述

  • 新建dev分支并切换,头指针指向dev分支,dev分支指向最新commit记录
    在这里插入图片描述

  • 在dev分支上做出新的commit,dev指针向前移动,master指针不变
    在这里插入图片描述

  • 将dev分支合并到master分支,需要先切换到master分支,head指向master分支,如果文件不冲突(master和dev分支没有修改同一处),那么master分支直接指向dev分支所指的commit
    在这里插入图片描述

  • 但如果出现冲突,例如master分支和dev分支都修改test文件中的同一行,这上合并就会出现冲突
    在这里插入图片描述

  • 解决办法是:再次修改test文件,生成新的commit,然后master指针就指向了新的commit,而此时dev分支也指向它,此处的commit有两个parent指针.
    在这里插入图片描述

merge和rebase的区别

假设当前在mywork分支,执行git merge origin可以将origin分支内容合并到当前分支,并生成一个新的commit在这里插入图片描述
执行git rebase origin,相当于将mywork的两次commit以补丁的形式合并到origin的最后一次commit上,会将原来的commit删除(C5,C6),创建新的commit(修改了历史commit,不建议使用)
在这里插入图片描述

⭐3.3 标签和模块管理

标签可以看做当前仓库当前分支最新commit时的一个快照

  • tag
  • git tag -l:查询所有标签
  • git tag -l 'v1.0':查询名称为v1.0的标签
  • git tag -a 'v1.0 -m':版本1’创建名称为v1.0的标签,注释为版本1
  • git tag -d v1.0:删除名称为v1.0的标签

关于submodule:Git工具——子模块

关于subtree:subtree工具同步多个子模块

相关内容

热门资讯

安卓子系统windows11,... 你知道吗?最近科技圈可是炸开了锅,因为安卓子系统在Windows 11上的兼容性成了大家热议的话题。...
电脑里怎么下载安卓系统,电脑端... 你有没有想过,你的电脑里也能装上安卓系统呢?没错,就是那个让你手机不离手的安卓!今天,就让我来带你一...
索尼相机魔改安卓系统,魔改系统... 你知道吗?最近在摄影圈里掀起了一股热潮,那就是索尼相机魔改安卓系统。这可不是一般的改装,而是让这些专...
安卓系统哪家的最流畅,安卓系统... 你有没有想过,为什么你的手机有时候像蜗牛一样慢吞吞的,而别人的手机却能像风一样快?这背后,其实就是安...
安卓最新系统4.42,深度解析... 你有没有发现,你的安卓手机最近是不是有点儿不一样了?没错,就是那个一直在默默更新的安卓最新系统4.4...
android和安卓什么系统最... 你有没有想过,你的安卓手机到底是用的是什么系统呢?是不是有时候觉得手机卡顿,运行缓慢,其实跟这个系统...
平板装安卓xp系统好,探索复古... 你有没有想过,把安卓系统装到平板上,再配上XP系统,这会是怎样一番景象呢?想象一边享受着安卓的便捷,...
投影仪装安卓系统,开启智能投影... 你有没有想过,家里的老式投影仪也能焕发第二春呢?没错,就是那个曾经陪你熬夜看电影的“老伙计”,现在它...
安卓系统无线车载carplay... 你有没有想过,开车的时候也能享受到苹果设备的便利呢?没错,就是那个让你在日常生活中离不开的iOS系统...
谷歌安卓8系统包,系统包解析与... 你有没有发现,手机更新换代的速度简直就像坐上了火箭呢?这不,最近谷歌又发布了安卓8系统包,听说这个新...
微软平板下软件安卓系统,开启全... 你有没有想过,在微软平板上也能畅享安卓系统的乐趣呢?没错,这就是今天我要跟你分享的神奇故事。想象你手...
coloros是基于安卓系统吗... 你有没有想过,手机里的那个色彩斑斓的界面,背后其实有着一个有趣的故事呢?没错,我要说的就是Color...
安卓神盾系统应用市场,一站式智... 你有没有发现,手机里的安卓神盾系统应用市场最近可是火得一塌糊涂啊!这不,我就来给你好好扒一扒,看看这...
黑莓平板安卓系统升级,解锁无限... 亲爱的读者们,你是否还记得那个曾经风靡一时的黑莓手机?那个标志性的全键盘,那个独特的黑莓体验,如今它...
安卓文件系统采用华为,探索高效... 你知道吗?最近安卓系统在文件管理上可是有了大动作呢!华为这个科技巨头,竟然悄悄地给安卓文件系统来了个...
深度系统能用安卓app,探索智... 你知道吗?现在科技的发展真是让人惊叹不已!今天,我要给你揭秘一个超级酷炫的话题——深度系统能用安卓a...
安卓系统的分区类型,深度解析存... 你有没有发现,你的安卓手机里藏着不少秘密?没错,就是那些神秘的分区类型。今天,就让我带你一探究竟,揭...
安卓系统铠无法兑换,揭秘无法兑... 最近是不是有很多小伙伴在玩安卓系统的游戏,突然发现了一个让人头疼的问题——铠无法兑换!别急,今天就来...
汽车安卓系统崩溃怎么刷,一键刷... 亲爱的车主朋友们,你是否曾遇到过汽车安卓系统崩溃的尴尬时刻?手机系统崩溃还能重启,但汽车系统崩溃了,...
miui系统可以刷安卓p系统吗... 亲爱的手机控们,你是否对MIUI系统情有独钟,同时又对安卓P系统的新鲜功能垂涎欲滴?今天,就让我带你...