Git及Github的使用

本文讲述Git的基本概念及本地库基本使用方法等。

以下任何[]在实际输入命令忽略即可,只是起到扩起目标词的作用--

版本控制工具:协同修改、数据备份、版本管理、权限控制、历史记录、分支管理。


Git的基本介绍

  • 是一种采用文件系统快照对的方式,对每个版本的文件信息进行管理的工具,即版本控制工具。SVN则采用增量式管理的方式。

  • 是一种分布式版本控制工具,而SVN则是集中式控制。

    1、分布式版本控制系统没有“中央服务器”,每个人的电脑都是一个完整的版本库,不用联网安全性相对于集中式版本控制系统要高很多。

    2、分布式版本控制系统还拥有强大的分支管理能力,允许开发团队在工作过程中多条生产线同时推进任务,大大提高效率。

  • 对团队外参与开发人员进行权限控制,对其代码进行审核。


Git命令行操作

1.设置签名

分别在命令行中输入以下代码,进行user.name和user.email的设置

git config --global user.name [user.name]

git config --global user.email [user.email]

--global 是系统用户级别,信息保存在:~/.gitconfig 文件中。

可以通过$ cat ~/.gitconfig命令查看。

2.创建本地库

选择合适的地方,创建空目录并进入(可以不按照默认路径)。

$mkdir gitwork
$cd gitwork

可以输入pwd查看当前显示的目录

3.仓库初始化

git init

初始化成功,当前目录下多出了.git目录,不能随意修改或者删除。

可以使用ls -ah查看隐藏的.git

4.状态查看

git status

当前为空库,所以no commits .分支为master.

5.添加文件

1、想要添加文件,得先写一个文件。用vim [filename]写一个.txt文件,关于vim的在此不做过多的探究,退出键为ESC,再输入:wq,文件便创建完成。

2、使用git add [filename]命令,将文件加到暂存区。

可以发现,出现了warning语句。注意:

warning: LF will be replaced by CRLF in app.wxss.

The file will have its original line endings in your working directory.

原因是路径中存在 / 的符号转义问题,false就是不转换符号默认是true,相当于把路径的 / 符号进行转义,这样添加的时候就有问题.解决方法就是输入以下命令,接着按原计划走。

git config --global core.autocrlf false

**添加文件夹->git add .->.代表当前目录所有。

6.提交文件

此时再次输入git status命令,可以查看仓库的状态,以加深对工作区,暂存区和本地库的理解。

一个新的文件被加入到暂存区,就是绿色部分所显示的。将“新建、修改”的文件添加至暂存区

git commit -m "message"[filename]

将暂存区的内容提交至本地库。

7.历史记录

git log

当然,这里作为演示,只有一步行为。在实际的应用过程中,版本更新的频率是很高的,所以为了看着舒适清晰,可以采用以下命令:

git log --pretty=oneline 包含sha1哈希值,指针指向,以及commit内容
git log --oneline 包含一小部分sha1哈希值,指针指向以及commit内容
git reflog 包含一小部分哈希值,HEAD@{移动到当前版本需要的步数}以及commit内容

8.前进后退

在提交了多次修改申请之后,界面变成如下:

  • 后退:git reset --hard HEAD^ 表示后退一步

提示:HEAD is now at f435d69 commit youfirst.txt

git reset --hard HEAD~n 表示后退n步

git reset --hard[index] 基于索引值

  • 前进:只能基于索引值,推荐使用。

前进或者后退,HEAD指针都在随着版本更新,在变化。


reset三个参数的对比

  • --soft:仅仅在本地库中移动HEAD指针。

  • --mixed:在本地库中移动HEAD指针。

    重置暂存区。

  • --hard:在本地库中移动HEAD指针。

    ​ 重置暂存区。

    ​ 重置工作区。


9.删除文件

前提:删除前,文件存在的状态提交到了本地库。

git reset --hard[指针位置]

  • 删除操作已经提交到了本地库:指针位置指向历史记录。
  • 删除操作尚未提交到本地库:指针位置使用HEAD。

10.比较文件差异

1、git diff[filename]:将工作区的文件和暂存区进行比较。

2、git diff[本地库中的历史版本][文件名]工作区本地库中的历史记录比较。

3、不带文件名比较多个文件。

最新文章

  1. C++_系列自学课程_第_9_课_C语言风格字符串_《C++ Primer 第四版》
  2. javascript判断给定字符串是否是回文
  3. Linux搭建DNS服务器
  4. ListView优化相关
  5. vlan知识
  6. homework做了些什么?
  7. 为什么JavaScript函数中的参数前面不能加var
  8. GitHub客户端Desktop的安装和使用总结
  9. IIS 加载 JSON 错误 404 解决办法
  10. Quartz+ssm注解方式的最最最最简单使用
  11. Visual Studio 2019 (VS2019)正式版安装 Ankh SVN和VisualSVN插件
  12. Jquery计算指定日期加上多少天、加多少月、加多少年的日期
  13. Codeforces Round #541 (Div. 2) E 字符串 + 思维 + 猜性质
  14. Beta阶段总结博客
  15. grid响应式布局
  16. MODIS产品分析和数据处理
  17. js实现隔行变色-------Day40
  18. Leecode刷题之旅-C语言/python-349两整数之和
  19. JS的从理解对象到创建对象
  20. linq.js的用法

热门文章

  1. Hystrix dashboard - Unable to connect to Command Metric Stream.
  2. kali2019里安装Burp Suite安装破解版加汉化版
  3. 关于./xhost: unable to open display问题的解决
  4. 一个自动管理项目的Makefile(C语言)
  5. 闯缸鱼:看懂python如何实现整数加和,再决定是否自学编程
  6. CAT客户端如何从Apollo中读取配置?
  7. continue和break在while中用法
  8. [考试反思]0903NOIP模拟测试36:复始
  9. 星空:差分,状压dp
  10. 2. 彤哥说netty系列之IO的五种模型