Git的简介

文章目录

下载Git 推荐官网下载
官网地址

一.Git是什么

Git是一个分布式版本控制系统,用于跟踪文件的变化并协调多人对同一项目的开发工作。它就像是一个时光机器,能够记录文件在不同时间点的状态,让开发者可以回溯文件的历史版本,比较不同版本之间的差异,以及轻松地恢复到之前的某个状态。

二.核心概念

  1. 仓库(Repository)
    • 仓库是Git用于存储项目文件及其版本历史的地方。可以把它想象成一个装满了文件各个版本的箱子。仓库分为本地仓库(存在于开发者自己的计算机上)和远程仓库(通常存储在服务器上,如GitHub、GitLab等平台)。
    • 例如,在开发一个软件项目时,本地仓库用于开发者在自己的电脑上进行代码的编写、修改和版本控制。而远程仓库则用于团队成员之间共享代码,方便多人协作开发。
  2. 提交(Commit)
    • 提交是Git中保存文件版本的操作。当开发者对文件进行了一系列的修改,并且这些修改达到了一个相对完整的阶段(比如完成了一个功能或者修复了一个bug),就可以将这些修改作为一个提交保存到仓库中。
    • 每个提交都有一个唯一的标识符(SHA - 1哈希值),并且包含了提交的作者、日期、提交说明等信息。例如,一个提交说明可能是"实现用户登录功能",这样其他开发者在查看版本历史时就能清楚地知道这个提交的目的。
  3. 分支(Branch)
    • 分支是仓库中独立的开发线。可以基于现有的分支创建新的分支,在新分支上进行开发而不影响其他分支。这就好比是在一条主道路上开辟出的小岔路,开发者可以在岔路上进行实验性的开发或者开发新的功能。
    • 例如,在开发一个网站时,有一个主分支(mastermain)用于保存稳定的、可以发布的代码。同时,可以创建一个feature - login分支用于开发用户登录功能,一个bug - fix - navbar分支用于修复导航栏的问题等。
  4. 合并(Merge)和变基(Rebase)
    • 当在不同分支上完成开发后,需要将这些分支的修改合并到主分支或者其他分支上。合并是将两个分支的修改整合到一起的操作。变基则是一种修改提交历史的方式,它可以让提交历史看起来更加线性。
    • 例如,在feature - login分支完成用户登录功能开发后,可以将这个分支合并到master分支,使master分支包含登录功能的更新。变基操作通常用于整理提交历史,比如将多个小的提交合并为一个更有意义的提交,或者将分支的提交移动到主分支提交的后面,使提交历史更加清晰。

三.工作流程

  1. 初始化仓库
    • 可以使用git init命令在本地创建一个新的Git仓库,或者使用git clone命令从远程仓库克隆一个副本到本地。例如,在一个新的项目文件夹中执行git init,就会在这个文件夹中创建一个隐藏的.git文件夹,它包含了仓库的所有版本控制信息。
  2. 修改文件和暂存(Staging)
    • 开发者对文件进行修改后,使用git add命令将修改后的文件添加到暂存区。暂存区就像是一个准备提交的区域,它可以让开发者选择哪些修改要包含在下次提交中。例如,修改了一个代码文件和一个配置文件后,可以使用git add.将当前目录下的所有修改添加到暂存区。
  3. 提交(Commit)
    • 使用git commit命令将暂存区的文件提交到本地仓库。在提交时,需要提供一个提交说明来描述这次提交的内容。例如,git commit -m "优化数据库查询性能"会将暂存区的文件作为一个新的提交保存到本地仓库,并附上提交说明。
  4. 推送(Push)和拉取(Pull)
    • 为了与团队成员协作,需要将本地仓库的提交推送到远程仓库(使用git push命令),也需要从远程仓库获取其他成员的提交(使用git pullgit fetch命令)。例如,在完成一个功能的开发并提交到本地仓库后,使用git push origin feature - loginfeature - login分支的提交推送到远程仓库的feature - login分支。

四.Git的优势

  1. 分布式协作
    • 每个开发者都拥有整个项目仓库的完整副本,包括所有的版本历史。这使得开发者即使在没有网络连接的情况下也能继续工作,并且可以方便地与其他开发者共享代码。例如,在一个跨国团队中,不同地区的开发者可以各自在本地仓库进行开发,然后定期将自己的修改推送到远程仓库与其他成员共享。
  2. 版本控制和历史记录
    • Git能够详细地记录文件的版本变化,这对于追踪问题、查看功能的开发过程以及回滚到之前的版本非常有用。例如,当发现新上线的功能导致了系统故障时,可以通过Git的版本历史快速定位到引入问题的提交,并将项目回滚到之前稳定的版本。
  3. 分支管理
    • 灵活的分支管理功能允许开发者同时进行多个功能的开发、实验新的想法,并且可以轻松地合并或放弃这些分支。这有助于提高开发效率,降低开发过程中的风险。例如,在开发一个大型软件时,可以通过创建多个分支来并行开发不同的模块,最后将这些分支的成果合并到主分支中。
相关推荐
大猫和小黄44 分钟前
Windows、CentOS环境下搭建自己的版本管理资料库:GitBlit
linux·服务器·windows·git
孤水寒月1 小时前
Git忽略文件.gitignore
git·elasticsearch
DN金猿10 小时前
git命令恢复/还原某个文件、删除远程仓库中的文件
git
DWei_GaGa12 小时前
Git:查看分支、创建分支、合并分支
git
涵信14 小时前
Windows11 安装 Ubuntu-20.04,同时安装配置 zsh shell,配置 git 别名(alias),大大提高开发效率
linux·git·ubuntu·bash
喝鸡汤17 小时前
一起学Git【第五节:git版本回退】
git
苏三有春1 天前
五分钟学会如何在GitHub上自动化部署个人博客(hugo框架 + stack主题)
git·go·github
high20111 天前
【Git】-- 版本说明
git
kaixin_learn_qt_ing1 天前
git clone
git