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

深入解析:【Git】Git 简介及基本操作

目录

  • 一、Git 简介
    • 1.1 LInux下安装Git
      • 1.1.1 centos下的命令
      • 1.1.2 ubuntu下的命令
  • 二、基本操作
    • 2.1 创建本地仓库
    • 2.2 配置本地仓库
    • 2.3 认识⼯作区、暂存区、版本库
    • 2.4 添加文件
    • 2.5 查看 .git
    • 2.6 修改文档
    • 2.7 版本回退
    • 2.8 撤销修改
      • 2.8.1 对于⼯作区的代码,还没有 add
      • 2.8.2 已经 add ,但没有 commit
      • 2.8.3 已经 commit
      • 2.9 删除材料

一、Git 简介

在工作和学习中,我们通常会遇到同一个报告、作业反复修改的时候,如果每一次修改后的版本都是有意义的,那么我们就要将每一个版本保存下来。但如果一旦修改过多,你还会记得这些版本各⾃都是修改了什么吗?

为了能够更⽅便我们管理这些不同版本的⽂件,便有了版本控制器。目前主流的版本控制器就是Git。

版本控制器:就是能让你了解到⼀个⽂件的历史,以及它的发展过程的系统。行记录⼯程的每⼀次改动和版本迭代的⼀个管理系统,同时也⽅便多⼈协同作业。

注意事项:

  • Git可以管理所有格式的文件;
  • 例如文本文件,你在文件中修改了什么,Git是可以记录下来的。
  • 但是二进制文件,你在文档修改了什么,Git是不知道的,只能记录每次修改导致文件大小的变化。

1.1 LInux下安装Git

1.1.1 centos下的命令

  1. 看看系统有没有安装Git:git --version。没有结果:-bash: git: command not found
  2. 安装 Git: sudo yum -y install git

1.1.2 ubuntu下的命令

  1. 看看系统有没有安装Git:git --version。没有结果:Command 'git' not found, but can be installed with:
  2. 安装 Git: sudo apt-get install git -y

二、基本操作

2.1 创建本地仓库

仓库是进⾏版本控制的⼀个⽂件⽬录。我们要想对⽂件进⾏版本控制,就必须先创建⼀个仓库出来。

  1. 创建一个目录: mkdir gitcode,进入目录:cd gitcode
  2. 创建本地仓库:git init

2.2 安装本地仓库

当安装 Git 后⾸先要做的事情是设置你的 ⽤⼾名称 和 e-mail 地址。

git config [--global] user.name "Your Name"
git config [--global] user.email "email@example.com"
# 把 Your Name 改成你的昵称
# 把 email@example.com 改成邮箱的格式,只要格式正确即可。
# 加上 --global 代表全局 会将本地的所有仓库都配置,删除时也要加上 -- global 才能删除。

git config -l查看配置项:

删除对应的配置命令为:

git config [--global] --unset user.name

git config [--global] --unset user.email

2.3 认识⼯作区、暂存区、版本库

  • 版本库(仓库):就是指上面创建的 .git 文件
  • 放入 gitcode 目录下的。所以我们将gitcode 目录下的区域(除 .git)称为 工作区。就是工作区:我们在上面是将 .git 创建在 gitcode 目录下的,由于我们是不能手动去对 .git 文件进行任何修改的,修改后可能导致本地仓库报废,我们的文件都
  • 暂存区 / 索引:英⽂叫 stage 或 index。⼀般存放在 .git ⽬录下的 index ⽂件(.git/index)中,大家把暂存区有时也叫作索引(index)。
    关系图

2.4 添加文件

先创建一个文件到工作区: touch ReadMe

  • 添加到暂存区:
    • git add .将当前工作区的文件全部添加
    • git add [file1] [file2] ... 将文件[file1] [file2] …添加
  • 提交到仓库
    • git commit -m "描述" 提交暂存区全部内容到本地仓库中
    • git commit [file1] [file2] ... -m "描述"提交暂存区 [file1] [file2] …到本地仓库中

git log 可以打印从近到远的所有提交记录:

2.5 查看 .git

  1. index 就是大家的暂存区,add 后的内容都是添加到这⾥的。
  2. HEAD 就是我们的默认指向 master 分⽀的指针.
  3. ⽽默认的 master 分⽀,其实就是: .git/refs/heads/master,存放的是最新一次提交的commit id

    打印的东西就是最新的commit id
  4. objects 为 Git 的对象库,⾥⾯包含了创建的各种版本库对象及内容。当执⾏ git add 命令时,暂存区的⽬录树被更新,同时⼯作区修改(或新增)的⽂件内容被写⼊到对象库中的⼀个新的对象中,就位于 “.git/objects” ⽬录下,
    查找 object 时要将 commit id 分成2部分,其前2位是⽂件夹名称,后38位是⽂件名称。使⽤git cat-file [option] [commit id] 命令来查看版本库对象的内容。

2.6 修改材料

大家Git本质上是 跟踪并管理 修改的,而不是文件本身。

查看当前仓库的状态:git status,⽤于查看在你上次提交之后是否有对⽂件进⾏再次修改。

查看工作区域仓库文件不同:git diff [file],⽤来显⽰暂存区和⼯作区⽂件的差异。
也可以使⽤ git diff HEAD -- [file] 命令来查看版本库和⼯作区⽂件的区别。

2.7 版本回退

执⾏ git reset 命令⽤于回退版本。
回退”本质是要将版本库中的内容进⾏回退,⼯作区或暂存区是否回退由命令参数决定:
语法格式为: git reset [--soft | --mixed | --hard] [HEAD]

  • --soft 参数对于⼯作区和暂存区的内容都不变,只是将版本库回退到某个指定版本。

  • --mixed 为默认选项,使⽤时可以不⽤带该参数。该参数将暂存区的内容退回为指定提交版本内容,⼯作区⽂件保持不变。

  • --hard 参数将暂存区与⼯作区都退回到指定版本。切记⼯作区有未提交的代码时不要⽤这个命令,因为⼯作区会回滚,你没有提交的代码就再也找不回了,所以使⽤该参数前⼀定要慎重。

HEAD 说明:

  • 可直接写成 commit id,表⽰指定退回的版本
    • HEAD 表⽰当前版本
    • HEAD^ 上⼀个版本
    • HEAD^^ 上上⼀个版本。 以此类推…
  • 也行使⽤ 〜数字表⽰:
    • HEAD~0表⽰当前版本
    • HEAD~1上⼀个版本
    • HEAD^2 上上⼀个版本。以此类推…

修改:

想吃后悔药了:

  • 当终端有原来的commit id的时候直接复制执行git reset命令即可:
  • 没有,就先使用git reflog命令拿到 commit id,再执行

2.8 撤销修改

垃圾,想恢复到上⼀个版本。就是我们的⼯作区写了很⻓时间代码,越写越写不下去,觉得⾃⼰写的实在

2.8.1 对于⼯作区的代码,还没有 add

创造条件:
-

不建议管理:

建议操作:

2.8.2 已经 add ,但没有 commit

创造条件:

操作:

  • git reset 回退命令,该命令如果使⽤--mixed 参数,可以将暂存区的内容退回为指定的版本内容,但⼯作区⽂件保持不变,就回到第一种情况了。
  • git reset 回退命令,该命令如果使⽤--hard 参数,工作区文件一起修改。

2.8.3 已经 commit

我们可以 git reset --hard HEAD^ 回退到上⼀个版本,有条件的,就是你还没有把⾃⼰的本地版本库推送到远程。

2.9 删除材料

  1. 先在工作区删除档案,再 add 和commit
  2. 使用git rm [filename] 删除工作区和暂存区的文件,在commit一下就行。
http://www.hskmm.com/?act=detail&tid=18035

相关文章:

  • hutool主要内容list
  • 20250916_QQ_Powershell
  • 完整教程:HTTP安全响应头--CSP(Content-Security-Policy)
  • 原码,反码,补码
  • Experiment1
  • 读书笔记:Oracle 自动索引:让数据库自己管索引?
  • 1_2025.9.26_1
  • 故障处理:Oracle RAC集群CTSS时钟同步故障案例分析与解决
  • Linux系统提权-web/普通用户-docker逃逸提权shell交互
  • PostgreSQL技术大讲堂 - 第106讲:分区表索引优化
  • 四边形不等式优化
  • 斜率优化
  • AI智能体:从认知到实践
  • Kinect屏幕边缘检测不灵敏的解决方案
  • 暴力拓客游戏小程序:助力商家高效引流与裂变的智能解决方案
  • vue3小坑之-为什么把ref定义的数组赋值给数组对象后取值为空数组?
  • 第二类斯特林数
  • 群论
  • 扫码签到赢大奖小程序:助力多场景获客的智能营销工具
  • docker 镜像/容器
  • jmeter命令行参数详细解释
  • RK3399:性能与能效的嵌入式先锋,解锁多场景应用潜力
  • 【C++STL详解】带头双向循环结构 + 双向迭代器,核心接口 + 排序效率 + 避坑指南 - 教程
  • TorchV知识库安全解决方案:基于智能环境感知的动态权限控制
  • VBA ETH功能应用 | “0”代码构建SOME/IP节点
  • ISUP协议视频平台EasyCVR在智慧灯杆综合管理中的应用
  • 视觉智能赋能产业数智化升级:JBoltAI多模态技术落地实践
  • 神秘考试题
  • 华三交换机升级版本步骤
  • Solon v3.4.6, v3.5.4, v3.6.0-M1 发布。正式开始 LTS 计划