$git学习总结系列(1)——基本用法
廖雪峰的官方网站:http://www.liaoxuefeng.com/
本文是学习廖雪峰的官方网站上git教程git基本用法的总结,详细内容可以进入廖雪峰的官方网站查看。
注:本文中的主要内容都是基于Linux环境进行操作的,使用的git版本为最新的2.10.2版本。文中命令示例中方括号里面的内容都表示是可选参数。
1. git与版本控制系统
git:分布式版本控制系统。
svn:集中式版本控制系统。
无论是分布式还是集中式版本控制系统,都只能对纯文本文件进行版本控制,而对二进制文件(如MS Word、MS Excel文档等)却都是无能为力的。
注意一点:文本文件必须统一使用utf-8格式编码,千万不要使用gbk编码!
2. 安装git
1. Linux环境(以Ubuntu为例)
(1) 查看当前有没有安装git
git
(2) 安装git
sudo apt-get install git
(3) 查看git版本
git --version
(4) 查看git帮助文档
有两种方法:
git
git --help
2. Windows环境
到 https://git-for-windows.github.io 上下载EXE安装包安装,安装完成后会有一个git bash命令行,然后在git bash命令行中其他操作和Linux下一致。
3. 配置git
1. 全局配置:
git config --global user.name "your_name"
git config --global user.email "your_email@example.com"
2. 在当前目录下初始化一个git版本库
git init
创建成功后,在当前目录下使用ls -al命令,可以看到创建了一个新的隐藏目录:.git,这就是git的版本库,注意不要手动修改其中的任何内容!
4. git工作区和暂存区、分支的关系
初始化成功一个git版本库后,会自动创建一个默认版本分支:master,以及一个暂存区(stage)。那么工作区(即用git init命令初始化后的硬盘文件夹)、暂存区、分支三者之间的关系是什么呢?搞清楚这一点对后面学习git的很多用法都非常重要,一图胜千言,见下图:
5. git 常用操作
准备:假如当前目录位于learngit文件夹,是一个空文件夹,首先在learngit目录初始化一个git版本库:
git init
这时发现在learngit文件夹下新建了一个隐藏目录:.git,然后在learngit目录下新建一个文本文件:readme.txt,并向其中任意添加一些内容。
1. 将readme.txt文件添加到版本库暂存区
git add readme.txt
附:git add的其他用法:
添加工作区的所有修改(包括新建、修改和删除文件这三种修改):
git add -A添加工作区中新建和修改文件的改动到暂存区,但不包括删除文件的改动:
git add *或git add .添加工作区修改和删除文件的改动到暂存区,但不包括新建文件的改动:
git add -u撤销单个或多个文件的add操作:
git reset 文件名1 文件名2...撤销当前所有add到暂存区的操作:
git reset
2. 删除文件
git rm 文件名1 文件名2...
3. 从暂存区提交修改(包括git add和git rm操作)到主分支
git commit -m "create a new file readme.txt"
注:git commit操作只会提交已经add到暂存区的修改,而工作区还未被add进暂存区的修改是不会被提交的。
4. 查看工作区状态
git status
5. 查看工作区和当前版本库最新版本之间的差别
git diff HEAD [-- 文件名1 文件名2...]
6. 撤销暂存区的修改(包括git add和git rm操作)
git reset HEAD [文件名1 文件名2...]
7. 查看commit操作的历史记录
git log [--pretty=oneline]
注:--pretty=oneline参数是为了在一行显示一条历史记录。
8. HEAD的理解
HEAD其实相当于一个指针,它指向的版本号就是当前版本库的最新版本。
HEAD:当前版本
HEAD^ :上一个版本
HEAD^^ :上上个版本
......
HEAD~100:往前100个版本
HEAD的指针作用可以用如下示意图表示:
从上图也可以看出,HEAD指针可以指向不同的版本,而这也正是下面要讲的版本回退和切换的原理。
9. 回退到某一个版本
回退到上一个版本:
git reset --hard HEAD^回退到某个版本:
git reset --hard 版本号
注:版本号可通过git log命令查看,只需要写前几位即可,git会自动识别匹配。
10. 回到未来
假如回退到之前的某个版本后,又后悔了不想回退了,想要撤销回退(即想要回到回退前的版本),可以使用如下命令:
先查看commit和reset命令的所有操作历史记录:
git reflog找到想要回到的未来的某个版本号,回到未来:
git reset --hard 版本号
随机推荐
- Git merge two repositories (ZZ)
转自 https://stackoverflow.com/questions/2428137/how-to-rebase-one-git-repository-onto-another-one If ...
- 指尖上的电商---(11)Windows平台部署SolrCloud
SolrCloud是一种分布式解决方式,是基于zookeeper和solr的,能够简单理解为一种集群,能够提供分布式查询.分布式写索引. SolrCloud的结构大致是这种,一个SolrCloud包含 ...
- jvisualvm远程调试
远程服务器端 (1)设置jstatd.all.policy 文件 grant codebase "file:${java.home}/../lib/tools.jar" { per ...
- 一种安全云存储方案设计(下)——基于Lucene的云端搜索与密文基础上的模糊查询
一种安全的云存储方案设计(未完整理中) 一篇老文了,现在看看错漏颇多,提到的一些技术已经跟不上了.仅对部分内容重新做了一些修正,增加了一些机器学习的内容,然并卵. 这几年来,云产品层出不穷,但其安全性 ...
- Tomcat虚拟目录
x先来看一段server.xml文件里的配置: <Host appBase="" autoDeploy="true" debug="0" ...
- log4j日志文件乱码问题的解决方法
近日在AIX上用log4j打印日志,出现乱码,经过努力解决问题. 症状:在默认语言非中文(或者说默认语言不支持中文的)的Windows.Linux.Unix上,用log4j打印日志,出现乱码,常见的就 ...
- Android无线测试之—UiAutomator工程建立
一.环境要求: 已经搭建好了Android UiAotomator测试环境 二.新建测试工程: 1.打开eclipse,首次打开指定一个工作空间 2.新建一个Java Project,名叫:Demo1 ...
- CodeMirror:基于JavaScript的代码编辑器
官方网站定义: http://codemirror.net/ CodeMirror is a versatile text editor implemented in JavaScript for t ...
- EF 批量更新删除(linq篇)
刚开始用EF很多东西都不会用,事后想想都很简单的东西总是用很麻烦的方式实现 1: EF的联合查询 inner join 很久很久以前我是这么写一个列表展示的,其中有两个字段Contractor和M ...
- 【BZOJ2064】分裂 状压DP
[BZOJ2064]分裂 Description 背景:和久必分,分久必和...题目描述:中国历史上上分分和和次数非常多..通读中国历史的WJMZBMR表示毫无压力.同时经常搞OI的他把这个变成了一个 ...