Git项目管理——提交项目和版本回退(二)

news2024/11/24 2:41:37

 个人名片:

🎓作者简介:嵌入式领域优质创作者
🌐个人主页:妄北y

📞个人QQ:2061314755

💌个人邮箱:[mailto:2061314755@qq.com]
📱个人微信:Vir2025WBY
🖋️本文为妄北y原创佳作,独家首发于CSDN🎊🎊🎊
💡座右铭:改造世界固然伟大,但改造自我更为可贵。

专栏导航:

妄北y系列专栏导航:

物联网嵌入式开发项目:大学期间的毕业设计,课程设计,大创项目,各种竞赛项目,全面覆盖了需求分析、方案设计、实施与调试、成果展示以及总结反思等关键环节。📚💼💡

QT基础入门学习:对QT的基础图形化页面设计进行了一个简单的学习与认识,利用QT的基础知识进行了翻金币小游戏的制作。🛠️🔧💭

Linux基础编程:初步认识什么是Linux,为什么学Linux,安装环境,进行基础命令的学习,入门级的shell编程。🍻🎉🖥️

Linux应用开发基础开发:分享Linux的基本概念、命令行操作、文件系统、用户和权限管理等,网络编程相关知识,TCP/IP 协议、套接字(Socket)编程等,可以实现网络通信功能。💐📝💡

Linux驱动开发:Linux驱动开发是Linux系统不可或缺的组成部分,它专注于编写特殊的程序——驱动程序。这些程序承载着硬件设备的详细信息,并扮演着操作系统与硬件间沟通的桥梁角色。驱动开发的核心使命在于确保硬件设备在Linux系统上顺畅运作,同时实现与操作系统的无缝集成,为用户带来流畅稳定的体验。🚀🔧💻

Linux项目开发:Linux基础知识的实践,做项目是最锻炼能力的一个学习方法,这里我们会学习到一些简单基础的项目开发与应用,而且都是毕业设计级别的哦。🤸🌱🚀

非常期待与您一同在这个广阔的互联网天地里,携手探索知识的海洋,互相学习,共同进步。🌐💫🌱 熠熠星光,照亮我们的成长之路

✨✨ 欢迎订阅本专栏,对专栏内容任何问题都可以随时联系博主,共同书写属于我们的精彩篇章!✨✨

文章介绍:

📚本篇文章将深入剖析GIT使用教程学习的精髓与奥秘,与您一同分享相关知识!🎉🎉🎉

若您觉得文章尚可入目,期待您能慷慨地送上点赞、收藏与分享的三连支持!您的每一份鼓励,都是我创作路上源源不断的动力。让我们携手并进,共同奔跑,期待在顶峰相见的那一天,共庆辉煌!🚀🚀🚀

🙏衷心感谢大家的点赞👍、收藏⭐和评论✍️,您的支持是我前进的动力!

目录:

目录:

一、GIT提交

1.1 常看当前工作目录的状态:

1.2 往暂存区中添加

1.3 添加到本地仓库

1.4 查看提交日志

二、版本回退 


一、GIT提交

先建立一个index.html文件

以下是文件内容:

1.1 常看当前工作目录的状态:

git status

  git status 是一个 Git 命令,它用于显示 Git 仓库中当前工作目录的状态。该命令会展示以下信息:

  1. 当前分支:显示你目前所在的分支。

  2. 变更追踪:显示已修改(modified)、已添加到暂存区(staged)、未跟踪(untracked)的文件。

  3. 文件状态

    • 已修改但未暂存(红色提示):文件已经修改,但尚未执行 git add 添加到暂存区。
    • 已暂存待提交(绿色提示):文件已经使用 git add 添加到暂存区,等待下一次提交。
    • 未跟踪文件:新文件或者是.gitignore中指定的不被Git跟踪的文件。
  4. 提示信息:可能会给出关于如何撤销改变或如何将改变添加到暂存区的提示。

 

1.2 往暂存区中添加

git add index.html     //文件名称

        当你执行 git add index.html 命令时,你是在告诉 Git 将 index.html 文件的更改添加到暂存区(staging area)。这意味着 index.html 文件中所有已经修改的内容将被标记为准备在下一个提交(commit)中包含。

  1. 修改文件:首先,你需要对 index.html 文件进行修改。

  2. 添加到暂存区:执行 git add index.html 命令,将修改后的 index.html 文件添加到暂存区。

  3. 检查状态:使用 git status 命令来查看哪些文件已经被暂存,哪些还没有。执行 git status 后,你会看到 index.html 文件的状态变为 "staged" 或 "to be committed"。

当文件存在多个的时候:

 

git add . 

   git add . 是一个 Git 命令,用于将当前目录下的所有新文件、修改过的文件和删除的文件添加到暂存区。这不包括那些被忽略的文件(例如,那些在 .gitignore 文件中指定的文件)。

        使用这个命令之后,所有的本地更改(新建、修改、删除的文件)将会被包含进暂存区,准备进行下一步的提交。这是快速准备大量更改进行提交的一个便捷方式,但是要谨慎使用,以确保不会意外添加不希望提交的更改。

        在执行 git add . 之后,可以使用 git status 来查看哪些更改已经被暂存,并且可以继续使用 git commit 命令来提交这些更改到仓库的历史记录中。

1.3 添加到本地仓库

把暂存区文件添加到本地仓库

git commit -m "提交说明"

  git commit -m "提交说明" 是一个 Git 命令,用于创建一个新的提交,将所有已暂存的更改记录到仓库历史中。这个命令中 -m 选项后面跟随的 "提交说明" 是提交消息,用于描述这次提交的目的或包含的更改内容。

         提交消息应该是清晰、简洁的,能够快速告诉其他参与项目的人这次提交做了什么。好的提交消息可以极大地提高项目的可维护性和协作效率。

         执行这个命令后,所有之前使用 git add 命令添加到暂存区的更改都会被包含在这次提交中。如果你之前没有执行过 git add 来暂存任何更改,那么 git commit -m "提交说明" 命令将不会提交任何东西,因为没有更改被暂存。

这里是执行 git commit -m "提交说明" 命令的一些步骤:

  1. 编辑和保存文件:对项目进行必要的修改,编辑相应的文件。

  2. 暂存更改:使用 git add <file>git add . 等命令将更改添加到暂存区。

  3. 提交更改:执行 git commit -m "提交说明" 来创建一个新的提交。将暂存区的内容和你提供的提交消息一起记录到仓库的历史中。

  4. 查看日志(可选):使用 git log 命令可以查看提交历史,确认你的提交已经被正确记录。

        如果在提交之后意识到提交消息有误或遗漏了一些更改,可以使用 git commit --amend 命令来修改最后一次提交,但请谨慎使用,因为这会改变仓库的历史。

 当我们资源更新之后

 

当我们文件发生变化后,再次查询会发现有出现了新的缓存:

 当我们每次整好一个版本项目,感觉已经是一个能够保存的节点了,我们就可以将暂存区的信息往本地仓库提交一下

1.4 查看提交日志

         git log是Git版本控制系统中一个非常有用的命令,它允许用户查看一个或多个分支的提交历史。这个命令展示了关于每次提交的详细信息,包括提交哈希值、作者、提交日期和提交信息等。这对于理解项目的发展历程、审查代码的变更以及追踪特定更改的来源等方面非常有帮助。

基本使用

        要查看当前分支的提交历史,简单地在Git仓库的根目录下运行:

git log 

常用选项

        查看每次提交的差异(显示每次提交中哪些行被添加或删除):

  git log -p

        查看最近的N次提交:

git log -n <N>

 其中`<N>`代表你想要查看的提交数目。

         按特定格式显示日志:

 git log --pretty=format:"%h - %an, %ar : %s"

这将会以一种简洁的格式显示提交,包括提交的哈希值、作者名字、提交日期和提交信息。

        显示特定文件或目录的日志:

git log -- <file/directory path>

只显示指定文件或目录的提交历史。

        图形化地显示提交树:

git log --graph

  这个选项以图形方式显示分支、合并历史。

高级搜索

        在特定日期之后的提交:

  git log --after="YYYY-MM-DD"

        指定作者的提交:

  git log --author="<author>"

        搜索提交信息中包含特定关键字的提交:

git log --grep="<keyword>"

结合使用选项

        你可以组合使用多个选项来定制你的日志输出,以满足具体需求。例如,如果你想看到过去两周内所有提交的统计信息(如每次提交的更改行数),你可以使用:

git log --since=2.weeks --stat

`git log`是一个强大的命令,提供了多种选项和过滤器来帮助你以不同的方式查看提交历史。掌握这个命令可以有效地帮助你管理和审查代码的历史变更。

查看所有的版本以及回退的记录 

git reflog

        git reflog 是 Git 中一个非常有用的命令,它记录了你的本地仓库中 HEAD 指针的移动历史。无论是因为提交(commit)、合并(merge)、重置(reset)还是其他原因,只要 HEAD 改变了位置,这些变动都会被记录在 reflog 中。这个命令对于恢复丢失的工作、找回因为误操作而消失的提交以及一般的仓库问题诊断来说都非常有帮助。

二、版本回退 

从本地仓库恢复回退到指定的版本

git reset --hard commit  //这里的commit是版本id号

   git reset --hard <commit>命令是Git中用于重置当前分支的HEAD到指定提交的一种方式,同时会清除工作目录中的所有变更。这意味着所有自那次提交以来的更改将会被丢弃,并且工作目录将会恢复到那次提交的状态。 

执行这个命令后将会发生以下几点:

  • 当前分支的HEAD(也就是当前分支的最新提交)将会被更新为指定的提交。
  • 暂存区将会被更新,以匹配那次提交的快照。
  • 工作目录中的所有文件将会被更新,以匹配那次提交的快照。
  • 所有自那次提交之后进行的更改将会被丢弃。

 

这里就回退到了第一次提交的版本 

警告

         使用git reset --hard要非常小心,因为这个命令会丢弃所有未提交的更改。如果你有任何未保存或未提交的工作,它们将会被永久删除。在执行此命令之前,确保你不需要那些更改,或者已经将它们保存在其他地方。

撤销git reset --hard

         如果你意识到执行了一个不希望的git reset --hard操作,有可能通过查找reflog来恢复丢弃的更改。Git的reflog记录了你本地仓库HEAD和分支指针的变化,可以帮助你找到丢失的提交。使用git reflog命令查看历史操作,然后可以使用git reset --hard <commit>命令恢复到你希望的状态,其中<commit>是你从reflog中找到的想要恢复到的提交ID。

          记住,git reset --hard是一个强大但危险的命令,只有在你确定要放弃所有更改时才使用它。

要想回退回去

 

📝大佬觉得本文有所裨益,不妨轻点一下👍给予鼓励吧!

❤️❤️❤️本人虽努力,但能力尚浅,若有不足之处,恳请各位大佬不吝赐教,您的批评指正将是我进步的动力!😊😊😊

💖💖💖若您认为此篇文章对您有所帮助,烦请点赞👍并收藏🌟,您的支持是我前行的最大动力!

🚀🚀🚀任务在默默中完成,价值在悄然间提升。让我们携手共进,一起加油,迎接更美好的未来!🌈🌈🌈

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1680730.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

嵌入式——C51版本Keil环境搭建

&#x1f3ac; 秋野酱&#xff1a;《个人主页》 &#x1f525; 个人专栏:《Java专栏》《Python专栏》 ⛺️心若有所向往,何惧道阻且长 文章目录 目标搭建流程下载与安装激活STC环境添加校验是否导入STC环境 目标 ● 了解C51版本Keil开发环境的概念和用途 ● 掌握C51版本Keil环…

PG Vacuum 空间管理工具与pg_freespacemap使用

1.什么是Vacuum&#xff1a; PG pageinspect使用与块空间清理学习-CSDN博客 之前说过PG块更新的特点:先删除后插入&#xff0c;但老元组并不会真正删除&#xff0c;只是把老元组标记为删除状态&#xff0c;这就导致了PG中会有大量的垃圾数据&#xff0c;update所造成的资源消…

LeetCode518:零钱兑换Ⅱ

题目描述 给你一个整数数组 coins 表示不同面额的硬币&#xff0c;另给一个整数 amount 表示总金额。 请你计算并返回可以凑成总金额的硬币组合数。如果任何硬币组合都无法凑出总金额&#xff0c;返回 0 。 假设每一种面额的硬币有无限个。 题目数据保证结果符合 32 位带符号…

进程信号 signal

文章目录 信号基础信号的产生OS中的时间 信号的保存sigset_tsigprocmasksigpending 信号的捕捉用户态和内核态sigactionvolatile SIGCHLD 信号基础 生活中的信号 你在网上买了很多件商品&#xff0c;再等待不同商品快递的到来。但即便快递没有到来&#xff0c;你也知道快递来临…

Blog搭建:pycharm+虚拟环境+django

pycharm创建项目 在pycharm新建项目&#xff0c;选择Django 项目名称&#xff1a;自定义项目位置&#xff1a;自定义创建git&#xff1a;方便上传到github选择虚拟环境方式venvpython解释器位置&#xff0c;和版本&#xff0c;如果你没有下载他会跳转到不同版本的供你下载temp…

分布式计算、并行计算、网格计算、边缘计算

分布式计算 分布式计算是一种计算方法&#xff0c;它将一个大型的计算任务分解成多个子任务&#xff0c;并将这些子任务分布在网络上的多台计算机&#xff08;节点&#xff09;上同时执行。这些节点通过通信网络协同工作&#xff0c;共同完成任务。每个节点可以独立处理自己的…

Skywalking配置traceId

1.引言 1.1 SkyWalking概述 SkyWalking是一个开源的分布式系统观测平台&#xff0c;旨在解决微服务和云原生架构中常见的性能监控和故障排除问题。自2015年由Apache基金会孵化以来&#xff0c;SkyWalking已经成为全球范围内广泛使用的APM&#xff08;应用性能管理&#xff09…

括号生成[中等]

优质博文&#xff1a;IT-BLOG-CN 一、题目 数字n代表生成括号的对数&#xff0c;请你设计一个函数&#xff0c;用于能够生成所有可能的并且 有效的 括号组合。 示例 1&#xff1a; 输入&#xff1a;n 3 输出&#xff1a;["((()))","(()())","(())(…

MATLAB车辆动力学建模 ——《控制系统现代开发技术》

引言 在上这门课之前&#xff0c;我已经用过CasADi 去做过最优化的相关实践&#xff0c;其中每一步迭代主要就是由&#xff1a;对象系统优化求解两部分组成的。这里我们重点介绍 “对象系统”如何去描述 &#xff0c;因为它是每一步迭代中重要的一环——“优化求解”会获得控制…

2024生日快乐祝福HTML源码

源码介绍 2024生日快乐祝福HTML源码&#xff0c;源码由HTMLCSSJS组成&#xff0c;记事本打开源码文件可以进行内容文字之类的修改&#xff0c;双击html文件可以本地运行效果&#xff0c;也可以上传到服务器里面&#xff0c; 源码截图 源码下载 2024生日快乐祝福HTML源码

【C++】学习笔记——多态_1

文章目录 十二、继承8. 继承和组合 十三、多态1. 多态的概念2. 多态的定义和实现虚函数重写的两个特殊情况override 和 final 3. 多态的原理1. 虚函数表 未完待续 十二、继承 8. 继承和组合 我们已经知道了什么是继承&#xff0c;那组合又是什么&#xff1f;下面这种情况就是…

哈希表+DFS快速解决力扣129题:求根节点到叶节点数字之和

❤️❤️❤️ 欢迎来到我的博客。希望您能在这里找到既有价值又有趣的内容&#xff0c;和我一起探索、学习和成长。欢迎评论区畅所欲言、享受知识的乐趣&#xff01; 推荐&#xff1a;数据分析螺丝钉的首页 格物致知 终身学习 期待您的关注 导航&#xff1a; LeetCode解锁100…

TypeScript高级类型 在鸿蒙中的使用 Partial、Required、Readonly、Pick、Record

我的工程代码在这里&#xff0c;持续更新中 欢迎交流&#xff0c;谢谢 https://github.com/MartinLi89/WanHarmony Partial <Type> 新定义 一个类型&#xff0c;将所有属性变为可选的类. class TextTS {a: string "1"b: string "2"c: string &…

(十一)Python基础练习题二(50道选择题)#Python

本文整理了Python基础知识相关的练习题&#xff0c;共50道&#xff0c;适用于刚入门初级Python想巩固基础的同学。来源&#xff1a;如荷学数据科学题库&#xff08;技术专项-Python一&#xff09;。序号之前的题请看往期文章。 51&#xff09; 52&#xff09; 53&#xff09; …

【数据结构】时间、空间复杂度实例分析

跌倒了&#xff0c;就重新站起来&#xff0c;继续向前走&#xff1b;傻坐在地上是没用的。&#x1f493;&#x1f493;&#x1f493; 目录 •✨说在前面 &#x1f34b;知识点一&#xff1a;算法的效率 • &#x1f330;1.斐波那契数列的第n项 • &#x1f330;2.算法的复杂度…

ChatGPT 4o 使用案例之一

2024年GPT迎来重大更新&#xff0c;OpenAI发布GPT-4o GPT-4o&#xff08;“o”代表“全能”&#xff09; 它可以接受任意组合的文本、音频和图像作为输入&#xff0c;并生成任意组合的文本、音频和图像输出。它可以在 232 毫秒内响应音频输入&#xff0c;平均为 320 毫秒&…

数学建模——建立数学模型(1)

前言 这个也是对《数学模型》&#xff08;姜启源第四版&#xff09;书内容的摘抄 建立数学模型 数学模型这个词汇现在越来越多地出现在现代入的 生产、工作和社会活动中&#xff0e;广大的科学技 术人员和应用数学工作者来说&#xff0c;建立数学模型是沟通摆在面前的实际问…

无人售货奶柜:掘金新零售蓝海,

无人售货奶柜&#xff1a;掘金新零售蓝海&#xff0c; 在日新月异的商业浪潮中&#xff0c;无人奶柜犹如一股清新的创业飓风&#xff0c;正以不可阻挡之势吸引着众多创业者的目光。这股新兴力量以其独到之处和庞大的市场蓝海&#xff0c;预示着一场关于健康、便捷消费方式的深…

荣耀MagicBook X 14 Pro锐龙版 2023 集显(FRI-H76)笔记本电脑原装出厂Windows11系统工厂模式安装包下载,带F10智能还原

恢复开箱状态预装OEM系统&#xff0c;适用型号&#xff1a;HONOR荣耀FRI-H76、FRI-H56 链接&#xff1a;https://pan.baidu.com/s/1Lcg45byotu5kDDSBs3FStA?pwdl30r 提取码&#xff1a;l30r 华为荣耀原装WIN11系统工厂安装包&#xff0c;含F10一键恢复功能、系统自带所有驱…

jvisualvm安装Visual GC插件

给jdk自带的jvisualvm安装Visual GC插件&#xff0c;遇到We’re sorry the java.net site has closed&#xff08;我们很抱歉java.net网站已经关闭&#xff09; 1、找到新的更新地址 visualvm新访问地址&#xff1a;https://visualvm.github.io/index.html 进入“Plugins”&am…