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

git入门教程6:git基本版本控制

一、初始化和配置Git仓库

  1. 安装Git

    • 首先,从Git的官方网站(git-scm.com)下载并安装Git。安装过程中按照提示操作即可。
  2. 初始化仓库

    • 打开终端或Git Bash,导航到你想要进行版本控制的项目目录。
    • 输入git init命令并按下回车键,Git将初始化一个新的仓库,并在当前目录下创建一个隐藏的.git目录。
  3. 配置用户信息

    • 使用git config --global user.name "你的姓名"git config --global user.email "你的邮箱@example.com"命令配置你的用户名和邮箱地址。这些信息将包含在每次提交中。

二、添加文件到暂存区

  1. 查看仓库状态

    • 使用git status命令查看当前仓库的状态,包括哪些文件被修改、哪些文件被暂存等。
  2. 添加文件到暂存区

    • 使用git add <文件或目录>命令将文件或目录添加到暂存区。如果你想要添加当前目录下的所有文件,可以使用git add .命令。

三、提交文件到仓库

  1. 提交文件

    • 一旦文件被添加到暂存区,你就可以使用git commit -m "提交信息"命令将它们提交到仓库中。提交信息应该简洁明了地描述这次提交的内容。
  2. 查看提交历史

    • 使用git log命令查看仓库的提交历史。这个命令会列出所有的提交记录,包括提交哈希值、作者、日期和提交信息。

四、版本控制基本操作

  1. 修改文件

    • 对仓库中的文件进行修改后,使用git status命令查看修改状态。
  2. 再次提交

    • 对修改后的文件进行git add操作,然后再次使用git commit -m "提交信息"命令提交更改。
  3. 查看文件差异

    • 使用git diff命令查看工作区与暂存区、暂存区与最新提交之间的文件差异。

五、撤销和重置操作

  1. 撤销暂存区的修改

    • 如果你不小心将错误的文件添加到了暂存区,可以使用git reset HEAD <文件>命令将文件从暂存区撤销。
  2. 撤销工作区的修改

    • 如果想要撤销工作区的修改,可以使用git checkout -- <文件>命令将文件恢复到最近一次提交的状态。
  3. 重置提交

    • 使用git reset --hard <提交哈希值>命令将仓库重置到指定的提交状态。这个操作会丢失该提交之后的所有更改。

六、查看和比较提交

  1. 查看特定提交的详细信息

    • 使用git show <提交哈希值>命令查看特定提交的详细信息,包括提交信息、作者、日期和提交差异。
  2. 比较两个提交之间的差异

    • 使用git diff <提交哈希值1> <提交哈希值2>命令比较两个提交之间的差异。

七、分支和合并操作

  1. 创建分支

    • 使用git branch <新分支名>命令创建一个新的分支。
  2. 切换分支

    • 使用git checkout <分支名>命令切换到指定的分支。
  3. 合并分支

    • 使用git merge <另一分支名>命令将另一个分支的更改合并到当前分支中。

八、远程仓库操作

  1. 克隆远程仓库

    • 使用git clone <仓库URL>命令克隆远程仓库到本地。
  2. 添加远程仓库

    • 使用git remote add <远程仓库名> <仓库URL>命令为本地仓库添加远程仓库。
  3. 推送更改到远程仓库

    • 使用git push <远程仓库名> <分支名>命令将本地分支的更改推送到远程仓库。
  4. 从远程仓库拉取更改

    • 使用git pull <远程仓库名> <分支名>命令从远程仓库拉取更改并合并到本地分支中。

通过以上步骤,你将能够掌握Git的基本版本控制操作,并能够在日常工作中高效地使用Git进行代码管理。


http://www.kler.cn/a/374510.html

相关文章:

  • Vue2四、 scoped样式冲突,data是一个函数,组件通信-父传子-子传父-非父子
  • 捋一捋相关性运算,以及DTD和NLP中的应用
  • C语言初阶习题【14】数9的个数
  • 多功能护照阅读器港澳通行证阅读机RS232串口主动输出协议,支持和单片机/Linux对接使用
  • stm32制作CAN适配器5--WinUsb上位机编写
  • 深入理解 HTTP HEAD 请求:节省带宽、提高效率的秘密武器
  • 中英文如何快速切换?小达人盘点10款翻译工具给你
  • 芯片技术创新,GPU 服务器厂家聚焦服务器性能新巅峰
  • Nuxt.js 应用中的 components:extend 事件钩子详解
  • CSS常用标签笔记
  • 详解汉明纠错码原理以及FPGA实现
  • Jetson Xavier nx在Ubuntu18.04下安装ros2 使用奥比中光330
  • Python+Appium+Pytest+Allure自动化测试框架-代码篇
  • springboot获取七牛云文件上传凭证token
  • 从二维图像到三维重建:由运动到结构(SfM)的完整流程推导【含数学原理及推导】
  • 基于STM32+华为云IOT设计的大棚育苗管理系统
  • Java 反射
  • 图论BFS
  • 微信小程序之流浪动物救助:爱与希望同行
  • 【SQL】 Navicate 17 连接sql server
  • 【小白学机器学习31】 大数定律,中心极限定理,标准正态分布与概率的使用
  • Vue2指令原理手写
  • 基于SSM+微信小程序的汽车预约维修管理系统(汽车3)
  • sublime text 常用快捷键
  • Chrome与夸克谁更节省系统资源
  • 宝塔使用clickhouse踩坑