git使用简介(代码片段)

loveyt loveyt     2022-12-25     270

关键词:

附上廖雪峰老师Git教程https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000

创建版本库

第一步

$ mkdir learngit
$ cd learngit
$ pwd
/Users/michael/learngit

第二步

通过git init命令把这个目录变成Git可以管理的仓库:
$ git init
Initialized empty Git repository in /Users/michael/learngit/.git/

git add与git commit

现在我们编写一个readme.txt文件,内容如下:
Git is a version control system.
Git is free software.

第一步

使用git add命令将文本添加到暂存区

$ git add readme.txt

第二步

使用git commit命令提交到版本库
$ git commit -m "wrote a readme file"
[master (root-commit) eaadf4e] wrote a readme file
1 file changed, 2 insertions(+)
create mode 100644 readme.txt
git commit命令,-m后面输入的是本次提交的说明,可以输入任意内容,当然最好是有意义的,这样你就能从历史记录里方便地找到改动记录。
补充

为什么Git添加文件需要add,commit一共两步呢?因为commit可以一次提交很多文件,所 以你可以多次add不同的文件,比如:

$ git add file1.txt
$ git add file2.txt file3.txt
$ git commit -m "add 3 files."

修改

运行git status命令看看结果:

$ git status
On branch master
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git checkout -- <file>..." to discard changes in working directory)

modified:   readme.txt

no changes added to commit (use "git add" and/or "git commit -a")
git status命令可以让我们时刻掌握仓库当前的状态,上面的命令输出告诉我们,readme.txt被修改过了,但还没有准备提交的修改。
虽然Git告诉我们readme.txt被修改了,但如果能看看具体修改了什么内容,自然是很好的。所以,需要用git diff这个命令看看:

$ git diff readme.txt 
diff --git a/readme.txt b/readme.txt
index 46d49bf..9247db6 100644
--- a/readme.txt
+++ b/readme.txt
@@ -1,2 +1,2 @@
-Git is a version control system.
+Git is a distributed version control system.
 Git is free software.

git diff顾名思义就是查看difference,显示的格式正是Unix通用的diff格式,可以从上 面的命令输出看到,我们在第一行添加了一个distributed单词。

> 要随时掌握工作区的状态,使用git status命令

版本回退

版本控制系统肯定有某个命令可以告诉我们历史记录,在Git中,我们用git log命令查看:

$ git log
commit 1094adb7b9b3807259d8cb349e7df1d4d6477073 (HEAD -> master)
Author: Michael Liao <[email protected]>
Date:   Fri May 18 21:06:15 2018 +0800

    append GPL

commit e475afc93c209a690c39c13a46716e8fa000c366
Author: Michael Liao <[email protected]>
Date:   Fri May 18 21:03:36 2018 +0800

    add distributed

commit eaadf4e385e865d25c48e7ca9c8395c3f7dfaef0
Author: Michael Liao <[email protected]>
Date:   Fri May 18 20:59:18 2018 +0800

    wrote a readme file

准备把readme.txt回退到上一个版本,也就是add distributed的那个版本,首先,Git必须知道当前版本是哪个版本,在Git中,用HEAD表示当前版本,也就是最新的提交1094adb...(注意我的提交ID和你的肯定不一样),上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100。

我们要把当前版本append GPL回退到上一个版本add distributed,就可以使用git reset命令:

$ git reset --hard HEAD^
HEAD is now at e475afc add distributed

看看readme.txt的内容是不是版本add distributed:

$ cat readme.txt
Git is a distributed version control system.
Git is free software.

Git提供了一个命令git reflog用来记录你的每一次命令

小结

  • HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用命令git reset --hard commit_id。
  • 穿梭前,用git log可以查看提交历史,以便确定要回退到哪个版本。
  • 要重返未来,用git reflog查看命令历史,以便确定要回到未来的哪个版本
  • 更详细的链接

工作区与暂存区

工作区

电脑里能看见的文档

版本库

工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。
Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD。

补充

需要提交的文件修改通过git add提交到暂存区。然后通过git commit一次性提交暂存区的所有修改


管理修改

> Git跟踪并管理的是修改,而非文件.每次修改,如果不用git add到暂存区,那就不会加入到commit中。

撤销修改

  • 场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout -- file。
  • 场景2:当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD
  • 场景3:已经提交了不合适的修改到版本库时,想要撤销本次提交,参考版本回退一节,不过前提是没有推送到远程库。

删除文件

要从版本库中删除该文件,那就用命令git rm删掉,并且git commit:

$ git rm test.txt
rm ‘test.txt‘

$ git commit -m "remove test.txt"
[master d46f35e] remove test.txt
 1 file changed, 1 deletion(-)
 delete mode 100644 test.txt

删错了,因为版本库里还有呢,所以可以很轻松地把误删的文件恢复到最新版本:

$ git checkout -- test.txt



git认识与使用git(代码片段)

文章目录1.Git概述1.1Git简介2.Git代码托管服务2.1常用到Git代码托管服务3.Git常用命令3.1Git全局设置3.2获取Git仓库3.2.1在本地初始化Git仓库3.2.2从远程仓库克隆3.3工作区、暂存区、版本仓库概念3.4Git工作区中文件的状态3.5本地仓库操... 查看详情

git认识与使用git(代码片段)

文章目录1.Git概述1.1Git简介2.Git代码托管服务2.1常用到Git代码托管服务3.Git常用命令3.1Git全局设置3.2获取Git仓库3.2.1在本地初始化Git仓库3.2.2从远程仓库克隆3.3工作区、暂存区、版本仓库概念3.4Git工作区中文件的状态3.5本地仓库操... 查看详情

git认识与使用git(代码片段)

文章目录1.Git概述1.1Git简介2.Git代码托管服务2.1常用到Git代码托管服务3.Git常用命令3.1Git全局设置3.2获取Git仓库3.2.1在本地初始化Git仓库3.2.2从远程仓库克隆3.3工作区、暂存区、版本仓库概念3.4Git工作区中文件的状态3.5本地仓库操... 查看详情

git复习之简介安装集中式和分布式(代码片段)

简介Git是分布式版本控制系统,使用C语言开发的,CVS、SVN是集中式的版本控制系统,集中式的版本控制系统不但速度慢,而且必须联网才能使用。 Git是分布式版本控制系统,同一个Git仓库,可以分布到不同的机器上。怎么... 查看详情

初识git(代码片段)

...控制系统)介绍Git项目的三个阶段Git命令集语法Git的使用获取Git仓库通常有两种方式:将项目导入Git设置忽略文件版本升级删除文件+版本回退Git简介Git是一个免费的开源分布式版本控制系统,旨在快速高效地处理... 查看详情

版本控制服务器——git(代码片段)

...作流程4.Git的几个核心概念二、基于Linux部署Git服务器1.Git使用2.验证三、使用GitHub1.注册账号2.在客户端上生成密钥对3.导入公钥密钥到GitHub4.创建储存空间5.将本地项目上传到GitHub6.查看GitHub文件7.同步远程仓库的最新状态到本地... 查看详情

git的认知与使用(代码片段)

...最近接触了《软件技术基础》课程,老师推荐我们了解和使用Git。在资料查询后做出整理:(资料来自https://www.git-scm.com/book/zh/v1)1、Git简介   Git是一个开源的分布式版本控制系统(DistributedVersionControlSystem,简称DVCS... 查看详情

git安装使用(代码片段)

Git安装配置使用一、git简介git是一个开源分布式版本控制系统,用于敏捷高效地处理任何或大或小的项目。Git是linusTovalds为了帮助管理Linux内核开发而开发的一个开放源码的版本控制软件。Git与常用的版本控制工具CVS,Subversion等... 查看详情

git使用教程(代码片段)

...介2、git与svn比较3、git的工作流程4、git分支管理三、git的使用1、安装2、基础命令四、过滤文件五、创建远程gitee仓库六、用本地仓库首次初始化远程仓库七、remote源操作八、多分支开发一、版本控制器概念"""完成协... 查看详情

极品,git简介,安装,方法(代码片段)

git是什么简单来说也就是版本管理器.版本管理器,基本上也分为两种:1.集中式管理:代表svn2.分布式管理:代表git集中式管理(svn)会出现问题-单点故障单点故障:把所有版本,所有工作区代码,放到一块管理,统一管理器如果出现问题,直... 查看详情

git的安装及其使用(代码片段)

 Git简介Git是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目Git是LinuxTorvalds为了帮助管理Linux内核开发而开发的一个开放源码的版本控制软件Git与常用的版本控制工具CVS,Subversion等不同,它采用了分... 查看详情

使用hexo搭建静态博客(代码片段)

目录Hexo简介什么是Hexo?Hexo安装Hexo建站Hexo配置Hexo自定义主题Hexo写作Hexo服务器Hexo生成与发布一键部署Hexo站点到githubpagesGithub仓库准备安装hexo-deployer-git插件修改_config.yml配置部署站点一键部署到自己的云服务器配置Nginx反向代理... 查看详情

git使用笔记01(代码片段)

...参考文章链接如下所示:ProGit(中文版)Git教程Git使用教程简介与说明Git是一个分布式版本管理系统,是为了更好地管理Linux内核开发而创立的。Git可以在任何时间点,把文档的状态作为更新记录保存起来。因此可... 查看详情

廖雪峰git教程笔记与总结--git简介常用命令分支管理(代码片段)

...一些常用命令做一个整理总结。本文要点分为:1、Git简介;2、Git常用命令;3、Git分支管理。一、Git简介什么是Git?Git是目前世界上最先进的分布式版本控制系统(没有之一)。Git的诞生个人觉得还是很有... 查看详情

git和github的使用(代码片段)

...安装和Github的注册5.1Git的安装5.2GitHub的注册6.Git和GitHub的使用6.1创建本地仓库6.2向本地仓库中添加文件6.3修改本地仓库中的文件内容并提交6.4删除本地仓库中的文件6.5将工程添加到本地仓库6. 查看详情

ci/cd之初识git(代码片段)

...控制系统)介绍Git项目的三个阶段Git命令集语法Git的使用获取Git仓库通常有两种方式:将项目导入Git设置忽略文件版本升级删除文件+版本回退Git简介Git是一个免费的开源分布式版本控制系统,旨在快速高效地处理... 查看详情

ci/cd之初识git(代码片段)

...控制系统)介绍Git项目的三个阶段Git命令集语法Git的使用获取Git仓库通常有两种方式:将项目导入Git设置忽略文件版本升级删除文件+版本回退Git简介Git是一个免费的开源分布式版本控制系统,旨在快速高效地处理... 查看详情

git使用规范(android版)(代码片段)

...ndroid开发中的Git版本管理规范。同时结合实际操作演示了使用示例,希望对你有所帮助。文章目录1.各分支简介master分支develop分支feature分⽀release分⽀release-fix分⽀fix分支refactor分支各分支关系图2.提交规范3.使用示例3. 查看详情