Git本地仓库基本操作及技巧

 更新时间:2020年08月05日 08:47:26   作者:chuyaoxin  
这篇文章主要介绍了Git本地仓库基本操作及一些小技巧,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

Git是什么?

一个分布式版本控制系统,和SVN类似,但远比SVN强大的一个版本控制系统 ①Git可以方便的在本地进行版本管理,如同你本地有一个版本管理服务器一样 我们可以选择在合适的时间将本地版本推送到统一的版本管理服务器 ②Git每次会提取整个代码仓库的完整镜像,相当于对整个代码仓库都进行了一次备份,这样计时版本服务器除了问题,我们可以直接采用本地仓库恢复!结合本地版本管理功能,远程版本管理服务器出问题了,我们依然能继续写自己的代码,当他恢复的时候我们再提交我们的本地版本! Git研发初期是为了更好的管理Linux内核,不过现在已经广泛应用于各种项目中!

下面看下Git本地仓库基本操作,具体内容如下所示:

设置姓名和邮箱

设置使用Git时的姓名和邮箱地址。名字须用英文输入
git config --global user.name "chuyaoxin"
git config --global user.email yaoxinchu@126.com

命令运行的结果是在“C:\Users\用户名”路径下,产生一个.gitconfig文件,可以用记事本打开。

想更改这些信息时,可以直接编辑这个设置文件。这里设置的姓名和邮箱地址会用在Git的提交日志中。由于在GitHub上公开仓库时,这里的姓名和邮箱地址也会随着提交日志一同被公开,所以请不要使用不便公开的隐私信息。

创建仓库

创建一个新文件夹,比如“TestForGit”
然后右键点击这个文件夹,选择Git Bash Here
打开后,输入git init完成代码仓库的建立

输入ls -al可以看到目录下有个.git的文件夹,但这个目录默认是隐藏的。

提交本地代码

先用add命令把要提交的内容都加进来,然后commit才是真的去执行提交操作。
第一步,用命令git add告诉Git,把文件添加到仓库
git add readme.txt
第二步,用命令git commit告诉Git,把文件提交到仓库
git commit -m "write a readme file"

.gitignore

.gitignore是Git的忽略配置文件,放在项目根目录下就行,这样在提交代码时就不会跟踪在.gitignore配置文件列举的文件。另外,.gitignore文件本身需要被git跟踪管理,不能被忽略。

git add

用途:可以用来跟踪新文件,或者添加已被修改的跟踪的文件到缓存区,或者把合并的冲突文件标记为已解决
git add的原意是更新当前工作目录树修改的内容到索引中(也就是缓存中去)
主要针对两种文件:(1)版本库没有跟踪的文件(2)版本库已经跟踪,但是修改了的文件
另外git add会自动忽略.gitignore文件所忽略的文件。

git add .
将文件的修改、文件的新建(注意!不包括被删除的文件),添加到暂存区
git add .会把所有untrack的文件都加入暂存区,并且会根据.gitignore做过滤

git add *
git add *会忽略.gitignore把任何文件都加入暂存区

git add -u
将文件的修改、文件的删除(注意!仅监控被add的文件,不包括新文件),添加到暂存区,u表示update

git add -A
将文件的修改,文件的删除,文件的新建(相当于add .与add -u的合集),添加到暂存区,A表示all其他
可以使用git add -h命令来查看

$ git add -h
usage: git add [<options>] [--] <pathspec>...
  -n, --dry-run     dry run
  -v, --verbose     be verbose
  -i, --interactive   interactive picking
  -p, --patch      select hunks interactively
  -e, --edit      edit current diff and apply
  -f, --force      allow adding otherwise ignored files
  -u, --update     update tracked files
  --renormalize     renormalize EOL of tracked files (implies -u)
  -N, --intent-to-add  record only the fact that the path will be added later
  -A, --all       add changes from all tracked and untracked files
  --ignore-removal   ignore paths removed in the working tree (same as --no-all)
  --refresh       don't add, only refresh the index
  --ignore-errors    just skip files which cannot be added because of errors
  --ignore-missing   check if - even missing - files are ignored in dry run
  --chmod (+|-)x    override the executable bit of the listed files
  --pathspec-from-file <file>
             read pathspec from file
  --pathspec-file-nul  with --pathspec-from-file, pathspec elements are separated with NUL character

git commit

git commit -m "write a readme file"

可以在使用了多次git add之后再使用git commit来提交。
在git commit命令中,-m后面输入的是本次提交的说明,可以输入任意内容,但最好是有意义的,这样就能从历史记录里方便地找到改动记录。
执行成功后,从图中可以看出,一个文件被改动,插入了6行内容。

git statusgit status
可以使用git status命令查看是否还有文件未提交

上图说明当前文件都已正常提交。
如果我对上传的文件进行修改,但是却不提交会如何?

会报出如上所示的错误!modified: readme.txt no changes added to commit
字面意思:readme.txt被修改,提交没有变化

git diffgit diff readme.txt
git status可以让我们知道有没有正常提交,比如上面那个例子,但如果要查看文件到底修改了什么内容,可以使用git diff 文件名命令

这条命令将我对这个文件的修改记录显示了出来

查看提交记录git log

使用git log即可查看历史提交信息

从这张图也可以看出之前git commit -m "write a readme file"中,-m部分的作用,这个和编程时写注释是一样的,可以不写,但是写的话方便以后的工作。
还有要注意的地方是输出的结果,
显然我这是提交了两次,以第一次的结果为例,

commit 418ee0fc27d78a71f5869451b5a1599cc028b0ca (HEAD -> master)
Author: chuyaoxin yaoxinchu@126.com
Date: Tue Aug 4 19:48:59 2020 +0800
write a readme file

对应的含义分别是

此次提交对应的版本号
提交人:姓名 邮箱
提交的时间
提交版本修改的内容:就是我们git commit -m “xxx”里的xxx

撤销未提交的修改

如果对文件进行了错误的修改,且已经Ctrl+S保存,但还没有提交,想要撤销之前的修改可以使用checkout命令

不仅未提交,而且没有add
如果是这种情况,只需要一句git checkout 修改的文件名即可
例如,git checkout readme.txt

此时,再打开readme.txt,我对此文件的第二次修改被取消掉了

已经add,但还没有提交
如果我们已经add了的话,那么直接checkout是没任何作用的,我们要先取消添加才可以撤回提交
git reset HEAD readme.txt
git checkout readme.txt

版本回退git reset
如果我们已经提交,但想退回到之前的版本,可以使用git reset命令
比如我先在readme.txt中添加了一行,然后git add readme.txtgit commit -m "add the third step",添加并提交到仓库
完成之后,使用git log检查提交记录。

PS:通过这张图也能看出,最新的版本号显示在最上方git reset --hard HEAD
在git中,HEAD表示当前版本,HEAD表示上一个版本,HEAD^表示上上个版本
退回到上一个版本需要依次输入以下指令
git reset --hard HEAD
git reset --hard HEAD^
执行结果如下图所示:

再输入git log查看,此时的版本号已经发生了变化,最新修改的那个版本号没有显示出来了

git reset --hard 版本号
这条命令可以让我们将当前版本更改为存在过的任意一个版本
同时仔细观察这张图,

可以很容易的猜到,其实版本号只要输入前七位就可以了
所以我们之前的回退指令可以用这条来替代,
git reset --hard 418ee0fgit reflog
如果你版本回退之后发现,还是最新的那个版本好一点,但此时通过git log已经找不到那个版本号了,
可以使用git reflog

显然,版本回退之前的最新版本号为14a5f92
然后使用git reset --hard 14a5f92
打开readme.txt,因为版本回退而去掉的修改又回来了

总结

到此这篇关于Git本地仓库基本操作及技巧的文章就介绍到这了,更多相关Git本地仓库基本操作内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vs2019生成dll并调用的实现示例

    vs2019生成dll并调用的实现示例

    这篇文章主要介绍了vs2019生成dll并调用的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-02-02
  • Git基本概述

    Git基本概述

    本文主要介绍了Git的基础知识。具有很好的参考价值,下面跟着小编一起来看下吧
    2017-01-01
  • git 报错:OpenSSL SSL_read: Connection was reset, errno 10054 解决方法

    git 报错:OpenSSL SSL_read: Connection was&

    这篇文章主要介绍了git 报错:OpenSSL SSL_read: Connection was reset, errno 10054 解决方法,涉及git配置信息及缓存相关操作技巧,需要的朋友可以参考下
    2023-04-04
  • Git 命令行教程及实例教程(附github注册)

    Git 命令行教程及实例教程(附github注册)

    这篇文章主要介绍了Git 命令行教程及实例教程,附github注册方法,需要的朋友可以参考下
    2017-10-10
  • git使用教程(最详细、最傻瓜)

    git使用教程(最详细、最傻瓜)

    这篇文章主要介绍了git使用教程(最详细、最傻瓜),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • Git远程仓库配置SSH的实现(以github为例)

    Git远程仓库配置SSH的实现(以github为例)

    本文主要介绍了Git远程仓库配置SSH的实现(以github为例),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-07-07
  • 多种编程语言的常用按键和语法

    多种编程语言的常用按键和语法

    就我所知道的语言来说,在键盘上集中分布跨度更大的语音,通常就是我们所指的丑陋的语言(阅读和编写代码都很困难),例如 shell 和 perl。
    2011-10-10
  • Git实现克隆历史的某个版本

    Git实现克隆历史的某个版本

    这篇文章主要介绍了Git实现克隆历史的某个版本,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-09-09
  • TortoiseGit的安装与配置教程

    TortoiseGit的安装与配置教程

    TortoiseGit是一个开放的GIT版本控制系统的源客户端,TortoiseGit 可以恢复您的文件的旧版本,并研究如何以及合适改变了历史数据,谁改变了它。下面教程针对使用TortoiseGit 的用户,感兴趣的朋友跟随小编一起看看吧
    2021-11-11
  • zend stdio8.0 快捷键汇总集合

    zend stdio8.0 快捷键汇总集合

    接下来小编就为大家介绍一下在Zend Stdio 8.0版本中的快捷键汇总。需要的朋友可以过来参考下,希望对大家有所帮助
    2013-10-10

最新评论