Git基础命令实践

文章目录

  • 简介
  • git的安装配置
    • git的安装
    • git的配置
  • git使用的基本流程
    • 创建版本库
    • 时光机穿梭
      • 版本回退
      • 工作区和暂存区
      • 管理修改
      • 撤销修改
      • 删除文件
  • 远程仓库
    • 添加远程库
    • 从远程库克隆
  • 总结

简介

本文主要记录了我在学习git操作的过程,以及如何使用GitHub。建议先参考廖雪峰的git教程实操练习一遍,再利用Learning Git Branching进行巩固。下文内容是对廖雪峰git教程的实践

git的安装配置

git的安装

我们可以直接下载GitHub Desktop:https://desktop.github.com/,下载自带了git bash,我们无需重复安装git,GitHub Desktop提供了详细的新手指引,我们根据指引提交我们的项目。
在这里插入图片描述

也可以下载git:https://git-scm.com/
在这里插入图片描述

git的配置

注意git config命令的--global参数,用了这个参数,表示你这台机器上所有的Git仓库都会使用这个配置,当然也可以对某个仓库指定不同的用户名和Email地址。

git config --global user.name "Your Name"
git config --global user.email "email@example.com"

git使用的基本流程

创建版本库

mkdir learngit
cd learngit

通过git init命令把这个目录变成Git可以管理的仓库:

git init

window里面可能无法显示.git文件,我们可以设置显示隐藏的项目。
在这里插入图片描述
现在我们编写一个readme.txt文件,内容如下:

Git is a version control system.
Git is free software.

在这里插入图片描述
第一步,用命令git add告诉Git,把文件添加到仓库:

git add readme.txt

第二步,用命令git commit告诉Git,把文件提交到仓库:

git commit -m "wrote a readme file"

git commit命令,-m后面输入的是本次提交的说明,可以输入任意内容,当然最好是有意义的,这样你就能从历史记录里方便地找到改动记录。

git commit命令执行成功后会告诉你,1 file changed:1个文件被改动(我们新添加的readme.txt文件);2 insertions:插入了两行内容(readme.txt有两行内容)。
在这里插入图片描述

为什么Git添加文件需要addcommit一共两步呢?因为commit可以一次提交很多文件,所以你可以多次add不同的文件,比如:
在这里插入图片描述
在这里插入图片描述
添加某个文件时,该文件必须在当前目录下存在,file4.txt文件不存在,因此报错。

时光机穿梭

版本回退

修改readme.txt文件如下

Git is a distributed version control system.
Git is free software distributed under the GPL.

然后进行提交:

git add readme.txt
git commit -m "append GPL"

在Git中,我们用git log命令查看历史记录:

git log

在这里插入图片描述

git log命令显示从最近到最远的提交日志,我们可以看到3次提交。

如果嫌输出信息太多,看得眼花缭乱的,可以试试加上--pretty=oneline参数:

git log --pretty=oneline

在这里插入图片描述
你看到的一大串类似59a9fdd...的是commit id(版本号),和SVN不一样,Git的commit id不是1,2,3……递增的数字,而是一个SHA1计算出来的一个非常大的数字,用十六进制表示,而且你看到的commit id和我的肯定不一样,以你自己的为准。为什么commit id需要用这么一大串数字表示呢?因为Git是分布式的版本控制系统,后面我们还要研究多人在同一个版本库里工作,如果大家都用1,2,3……作为版本号可能发生冲突。

首先,Git必须知道当前版本是哪个版本,在Git中,用HEAD表示当前版本,也就是最新的提交599fdd...(注意我的提交ID和你的肯定不一样),上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上1000个版本写1000个^比较容易数不过来,所以写成HEAD~1000。

可以使用git reset命令进行版本回退:

git reset --hard HEAD^^

在这里插入图片描述
我们发现回退到了未修改readme.txt的那个版本。
在这里插入图片描述
Git的版本回退速度非常快,因为Git在内部有个指向当前版本的HEAD指针。

那我们如何对版本进行恢复呢?这里有两种方法:

  • 情形一:直接利用commit id指定回到未来某个版本
    在这里插入图片描述
  • 情形二:当我们不知道commit id时,Git提供了一个命令git reflog用来记录你的每一次命令,下面例子我们可以看出指针上一次指向59a9fdd
    在这里插入图片描述

工作区和暂存区

工作区(Working Directory)
就是你在电脑里能看到的目录,比如我的learngit文件夹就是一个工作区:
在这里插入图片描述
版本库(Repository)
工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。

Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD
在这里插入图片描述
Git自动为我们创建了唯一一个master分支,所以,现在,git commit就是往master分支上提交更改。

你可以简单理解为,需要提交的文件修改通通放到暂存区,然后,一次性提交暂存区的所有修改。

下面举一个例子:

  1. 先对readme.txt做个修改,比如加上一行内容:

Git is a distributed version control system.
Git is free software distributed under the GPL.
Git has a mutable index called stage.

在这里插入图片描述
2. 在工作区新增一个LICENSE文本文件
在这里插入图片描述
git status查看状态
在这里插入图片描述
使用两次命令git add,把readme.txtLICENSE都添加

git add readme.txt
git add LICENSE.txt
git status

在这里插入图片描述
现在,暂存区的状态就变成这样了:
在这里插入图片描述
执行git commit就可以一次性把暂存区的所有修改提交到分支

git commit -m "understand how stage works"
git status

在这里插入图片描述
现在版本库变成了这样,暂存区就没有任何内容了:
在这里插入图片描述

管理修改

Git跟踪并管理的是修改,而非文件。

现在我们加上一行内容:

Git is a distributed version control system.
Git is free software distributed under the GPL.
Git has a mutable index called stage.
Git tracks changes.

在这里插入图片描述

git add readme.txt
git status

在这里插入图片描述

然后再修改readme.txt文件:

Git is a distributed version control system.
Git is free software distributed under the GPL.
Git has a mutable index called stage.
Git tracks changes of files.

最后直接进行提交:

git commit -m "git tracks changes"
git status

在这里插入图片描述

我们发现第二次的修改没有被提交,这是因为第二次的修改没有通过git add放入缓存区,我们可以通过git diff HEAD -- readme.txt命令可以查看工作区和版本库里面最新版本的区别:

git diff HEAD -- readme.txt 

在这里插入图片描述

可见第二次修改没有被提交,我们可以git add后进行git commit进行提交。
在这里插入图片描述

撤销修改

情形一:还未git add

Git is a distributed version control system.

Git is free software distributed under the GPL.

Git has a mutable index called stage.

Git tracks changes of files.

My stupid boss still prefers SVN.

在这里插入图片描述
使用git status查看一下,Git会告诉你,git restore可以丢弃工作区的修改:

git restore readme.txt

在这里插入图片描述

在这里插入图片描述
情形二:已经git add到暂存区

在这里插入图片描述

git restore --staged readme.txt #暂存区回退
git restore readme.txt #工作区回退

在这里插入图片描述
在这里插入图片描述
情形三:已经git commit,还没有推送到远程库中
在这里插入图片描述

git add readme.txt
git commit -m "fallback version"

在这里插入图片描述

git reflog
git reset --hard 389d734

在这里插入图片描述
在这里插入图片描述

删除文件

在这里插入图片描述
情况一:直接删除
这里删除file1.txt文件
在这里插入图片描述
情况二:删错了,利用版本库对工作区文件进行还原。
这里删除file2.txt文件
在这里插入图片描述
在这里插入图片描述
最后我们发下file1.txt文件被删除了,file2.txt文件还原了。

注意:从来没有被添加到版本库就被删除的文件,是无法恢复的!

远程仓库

添加远程库

在这里插入图片描述
在这里插入图片描述

git remote add origin https://github.com/liuxu-manifold/learngit.git

由于远程库是空的,我们第一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。

git push -u origin master

在这里插入图片描述

推送成功后,可以立刻在GitHub页面中看到远程库的内容已经和本地一模一样:
在这里插入图片描述
删除与远程库的关联
如果添加的时候地址写错了,或者就是想删除远程库,可以用git remote rm <name>命令。使用前,建议先用git remote -v查看远程库信息:

git remote -v
git remote rm origin

在这里插入图片描述
此处的“删除”其实是解除了本地和远程的绑定关系,并不是物理上删除了远程库。远程库本身并没有任何改动。要真正删除远程库,需要登录到GitHub,在后台页面找到删除按钮再删除。

从远程库克隆

如何解决 git@github.com permission denied (publickey). fatal could not read from remote repository
:https://zhuanlan.zhihu.com/p/454666519

git clone git@github.com:liuxu-manifold/liuxu-manifold.git

总结

本文记录了我在学习git过程中的一些常用命令,当我们对git有一个整体而全面的认识之后,我们后面可以通过查文档,或者GPT来完成任务。

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

AI:45-基于深度学习的声纹识别

🚀 本文选自专栏:AI领域专栏 从基础到实践,深入了解算法、案例和最新趋势。无论你是初学者还是经验丰富的数据科学家,通过案例和项目实践,掌握核心概念和实用技能。每篇案例都包含代码实例,详细讲解供大家学习。 📌📌📌本专栏包含以下学习方向: 机器学习、深度学…

Linux--文件操作

1.什么是文件 对于文件来说&#xff0c;文件文件内容文件属性&#xff1b;对于文件来说&#xff0c;只有两种操作&#xff0c;对内容的修改和对文件属性的修改&#xff0c;这就是文件的范畴。 对于存放在磁盘上的文件&#xff0c;我们需要通过进程来进行访问&#xff0c;访问文…

【JQuery-XSS漏洞(CVE-2020-11022/CVE-2020-11023)漏洞复现】

文章目录 一、漏洞描述二、受影响版本三、漏洞复现四、漏洞危害五、修复建议 一、漏洞描述 进行在公司内部用nessus做漏洞扫描时&#xff0c;发现某台服务器报出这个中危漏洞&#xff0c;后面查资料复现。 根据脚本中的自我报告版本&#xff0c;远程web服务器上托管的JQuery版…

2024年湖北武汉建筑企业三类人员安全员ABC怎么报考

2024年湖北武汉建筑企业三类人员安全员ABC怎么报考 武汉建筑企业报考三类人员&#xff0c;建筑单位归属地在武汉&#xff0c;且有建筑相关的一些资Z&#xff0c;才可以申报一定数量的三类人员、安全员ABC、建筑安全员ABC、专职安全员C证、建设厅安全员ABC证。 建筑企业-报考建…

IDEA 使用技巧

文章目录 语言支持简化编写 有问题&#xff0c;可暂时跳过 个人常用快捷键插件主题插件功能插件 碰到过的问题 除了一些在Linux上用vim开发的大佬&#xff0c;idea算是很友好的集成开发工具了&#xff0c;功能全面&#xff0c;使用也很广泛。 记录一下我的 IDEA 使用技巧&#…

TestCenter测试管理工具

estCenter&#xff08;简称TC&#xff09;一款广受好评的测试管理工具&#xff0c;让测试工作更规范、更有效率&#xff0c;实现测试流程无纸化&#xff0c;测试数据资产化。 产品概述 TC流程图 产品功能 一、案例库 案例库集中化管理&#xff0c;支持对测试用例集中管理&…

Java架构师软件可靠性构建

目录 1 导学2 软件可靠性基本概念3 软件可靠性建模4 软件可靠性管理5 软件可靠性设计6 软件可靠性测试与评价想学习架构师构建流程请跳转:Java架构师系统架构设计 1 导学 2 软件可靠性基本概念 软件可靠性是软件产品在规定的条件下和规定的时间区间完成规定功能的能力。软件…

极智AI | 从大模型角度看苹果M3系列芯片

欢迎关注我的公众号 [极智视界],获取我的更多经验分享 大家好,我是极智视界,本文来介绍一下 从大模型角度看苹果M3系列芯片。 邀您加入我的知识星球「极智视界」,星球内有超多好玩的项目实战源码下载,链接:https://t.zsxq.com/0aiNxERDq 北京时间今天早上,Apple 发布了…

0代码0侵入的安卓骨架屏框架----二期优化

本文是对自定义骨架屏框架的优化说明。 针对目前对骨架屏的需求及为了实现骨架屏而付出的繁重劳动&#xff0c;而设计的一款0编码0业务侵入的骨架屏框架。感兴趣的可以先去看看这篇文章&#xff1a;一种简单的Android骨架屏实现方案----0侵入0成本 额&#xff0c;如果不看&am…

Linux系统封装ISO镜像(自动安装)

一、准备一个系统 centos7或者centos8都可以;最小化或者桌面版的都可以,自行选择 二、安装自定义镜像工具 yum -y install createrepo mkisofs openssl rsync syslinux三、挂载镜像 创建挂载点 mkdir /mnt/cdrommount /dev/sr0 /mnt/cdrom四、同步 /mnt/cdrom/ 下的文件到 …

【Spring Boot 源码学习】RedisAutoConfiguration 详解

Spring Boot 源码学习系列 RedisAutoConfiguration 详解 引言往期内容主要内容1. Spring Data Redis2. RedisAutoConfiguration2.1 加载自动配置组件2.2 过滤自动配置组件2.2.1 涉及注解2.2.2 redisTemplate 方法2.2.3 stringRedisTemplate 方法 总结 引言 上篇博文&#xff0…

论文阅读 - Detecting Social Bot on the Fly using Contrastive Learning

目录 摘要&#xff1a; 引言 3 问题定义 4 CBD 4.1 框架概述 4.2 Model Learning 4.2.1 通过 GCL 进行模型预训练 4.2.2 通过一致性损失进行模型微调 4.3 在线检测 5 实验 5.1 实验设置 5.2 性能比较 5.5 少量检测研究 6 结论 https://dl.acm.org/doi/pdf/10.1145/358…