【知识小结】Git 个人学习笔记及心得
https://mp.weixin.qq.com/s/D96dXYfu3XAA4ac456qo0g
git架构

- 工作区:就是你在电脑里能看到的目录。 
- 版本库:工作区有一个隐藏目录.git,,而是Git的版本库。 
- 暂存区:英文叫stage, 或index。一般存.git/index中,所以我们把暂存区有时也叫作索引(index)。 
- HEAD:指向 master 分支的一个"游标" 
- objects:位于 ".git/objects" 目录下,里面包含了创建的各种对象及内容。 
- git add:暂存区的目录树被更新,同时工作区修改(或新增)的文件内容被写入到对象库中的一个新的对象中,而该对象的ID被记录在暂存区的文件索引中。 
- git commit:当执行提交操作时,暂存区的目录树写到版本库(对象库)中,master 分支会做相应的更新。 
- git reset HEAD:取消已缓存的内容,但是工作区不受影响。 
- git rm --cached <file>:会直接从暂存区删除文件,工作区则不做出改变。 
- git checkout ." 或者 "git checkout -- <file>":会用暂存区全部或指定的文件替换工作区的文件。这个操作很危险,会清除工作区中未添加到暂存区的改动。 
- git checkout HEAD ." 或者 "git checkout HEAD <file>" :会用 HEAD 指向的 master 分支中的全部或者部分文件替换暂存区和以及工作区中的文件。这个命令也是极具危险性的,因为不但会清除工作区中未提交的改动,也会清除暂存区中未提交的改动。 
git config
· /etc/gitconfig 文件:系统中对所有用户都普遍适用的配置。若使用 git config 时用 --system 选项,读写的就是这个文件。
· ~/.gitconfig 文件:用户目录下的配置文件只适用于该用户。若使用 git config 时用 --global 选项,读写的就是这个文件。
· 当前项目的 Git 目录中的配置文件(也就是工作目录中的 .git/config 文件):这里的配置仅仅针对当前项目有效。
$ git config --global user.name "runoob"  
$ git config --global user.email test@runoob.com  
$ git config --list  
$ git config user.name  git clone
git clone http://github.com/CosmosHua/locate new  
git clone http://github.com/CosmosHua/locate.git new  
git clone git://github.com/CosmosHua/locate new  
git clone git://github.com/CosmosHua/locate.git new  
git status -s
#-s 参数,以获得简短的结果输出  
"AM" 状态的意思是,这个文件在我们将它添加到缓存(git add)之后又有改动  
“??”未add  
“A”已经add  
git diff
查看比 git status 的结果的详细信息。
git diff 命令显示已写入缓存与已修改但尚未写入缓存的改动的区别。git diff 有两个主要的应用场景。
- 尚未缓存的改动:git diff 
- 查看已缓存的改动: git diff --cached 
- 查看已缓存的与未缓存的所有改动:git diff HEAD 
- 显示摘要而非整个 diff:git diff --stat 
git reset HEAD
取消已缓存的内容。
- $ git reset HEAD -- hello.php 取消其中一个缓存的文件 
git rm
如果删除之前修改过并且已经放到暂存区域的话,则必须要用强制删除选项 -f
git rm -f <file>
如果把文件从暂存区域移除,但仍然希望保留在当前工作目录中。
git rm --cached <file>
git如何撤销上一次commit操作
git reset --soft|--mixed|--hard <commit_id>  
git push develop develop --force  (本地分支和远程分支都是 develop)  
<span style="color:#ff0000;">这里的<commit_id>就是每次commit的</span><strong><span style="color:#ff0000;">SHA-1</span></strong>,可以在log里查看到  
--mixed    会保留源码,只是将git commit和index 信息回退到了某个版本.  
--soft   保留源码,只回退到commit信息到某个版本.不涉及index的回退,如果还需要提交,直接commit即可.  
--hard    源码也会回退到某个版本,commit和index 都会回退到某个版本.(注意,这种方式是改变本地代码仓库源码)  
git branch
创建分支命令:  
git branch (branchname)  
切换分支命令:  
git checkout (branchname)  
当你切换分支的时候,Git 会用该分支的最后提交的快照替换你的工作目录的内容。  
git checkout -b (branchname) 命令来创建新分支并立即切换到该分支下  
git merge secondBranch #merge secondBrach to master,可以不用切回master branch  
你可以多次合并到统一分支, 也可以选择在合并之后直接删除被并入的分支。  
删除分支命令:  
git branch -d (branchname)  
Git log
查看历史提交记录  
Git log  
查看简洁版  
Git log –-oneline  
git tag
如果你达到一个重要的阶段,并希望永远记住那个特别的提交快照,你可以使用 git tag 给它打上标签。
-a 选项意为"创建一个带注解的标签"。不用 -a 选项不会记录这标签是啥时候打的,谁打的,也不会让你添加个标签的注解。
$ git tag -a v1.0 –m “first tag”  
如果我们忘了给某个提交打标签,又将它发布了,我们可以给它追加标签  
$ git tag -a v0.9 85fc7e7  
$ git log --oneline 可以看到  
git remote
添加远程库
要添加一个新的远程仓库,可以指定一个简单的名字,以便将来引用,命令格式如下:
git remote add [shortname] [url]  
git remote add remoteServer https://github.com/Courage-Freadom/hello-world/  
git push -u remoteServer master  
查看远程仓库  
$ git remote -v  
从远程仓库下载新分支,该命令执行完后需要执行git merge  
git fetch  
从远端仓库提取数据并尝试合并到当前分支:  
git merge  
【知识小结】Git 个人学习笔记及心得的更多相关文章
- 从实例学习 Go 语言、"并发内容" 学习笔记及心得体会、Go指南
		第一轮学习 golang "并发内容" 学习笔记,Go指南练习题目解析.使用学习资料 <Go-zh/tour tour>.记录我认为会比较容易忘记的知识点,进行补充,整 ... 
- git的学习笔记(二):git远程操作
		1.创建ssh key ssh-keygen -t rsa -C "your_email@example.com" 执行命令后会在用户的家目录生成.ssh的隐藏文件夹,文件夹里有公 ... 
- git的学习笔记整理
		Git学习较好的网址:http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/001373 ... 
- HIT2019春软件构造->Git&Github学习笔记
		由于软件构造课程需要,学习使用git,以下作为学习笔记. 一.Git初始化及仓库创建和操作 1.基本信息设置(设置签名) 命令 项目级别/仓库级别:仅在当前本地库范围内有效 git ... 
- Git操作学习笔记
		根据廖雪峰老师git教程学习整理 这里需要辨析一下概念.Github是代码托管平台,是协作的工具;而Git是版本控制工具.Git不需要联网,在本机就可以使用 集中式版本控制系统与分布式版本控制系统 S ... 
- 廖雪峰 Git教程学习笔记 原文 http://www.liaoxuefeng.com/
		一 .集中式与分布式 先说集中式版本控制系统,版本库是集中存放在中央服务器的,而干活的时候,用的都是自己的电脑,所以要先从中央服务器取得最新的版本,然后开始干活,干完活了,再把自己的活推 ... 
- git/github学习笔记
		郑重提示,本文来自这里,如果喜欢,请关注原作者. 1. git 版本控制系统 相比CVS\SVN优势: - 支持离线开发,离线Repository- 强大的分支功能,适合多个独立开发者协作- 速度块 ... 
- 从实例学习 Go 语言、"基础与进阶" 学习笔记及心得体会、Go指南
		第一轮学习 golang "基础与进阶"学习笔记,Go指南练习题目解析.使用学习资料 <Go-zh/tour tour>.记录我认为会比较容易忘记的知识点,进行补充,整 ... 
- 版本控制工具Git的学习笔记
		在网上看到一个很不错的Git教程,学习后果断要做一下总结. 教程地址:http://www.liaoxuefeng.com/ 总结要点: 安装Git因为我个人的开发主要是基于windows环境下,所以 ... 
随机推荐
- Minimal coverage (贪心,最小覆盖)
			题目大意:先确定一个M, 然后输入多组线段的左端和右端的端点坐标,然后让你求出来在所给的线段中能够 把[0, M] 区域完全覆盖完的最少需要的线段数,并输出这些线段的左右端点坐标. 思路分析: 线段区 ... 
- python之高阶函数--map()和reduce()
			以下为学习笔记:来自廖雪峰的官方网站 1.高阶函数:简单来说是一个函数里面嵌入另一个函数 2.python内建的了map()和reduce()函数 map()函数接收两参数,一个是函数,一个是Iter ... 
- Docker数据管理-数据卷 data volumes和数据卷容器data volumes containers的使用详解
			此文来源于:https://yq.aliyun.com/ziliao/43471 参考原文件之外,做了些修改. Volume数据卷是Docker的一个重要概念.数据卷是可供一个或多个容器使用的特殊目录 ... 
- Redis → 下载安装及启动
			一.Window 下安装 下载地址:https://github.com/MSOpenTech/redis/releases Redis 支持 32 位和 64 位.这个需要根据你系统平台的实际情况选 ... 
- Hello World 之Spring Boot 调用图数据库Neo4j
			明日歌 [清]钱鹤滩 明日复明日,明日何其多! 我生待明日,万事成蹉跎 1. 图数据库Neo4j之爱的初体验 ----与君初相识,犹似故人归 在如今大数据(big data)横行的时代,传统的关系型数 ... 
- Oracle SQL——如何用一个表的数据更新另一个表中的数据
			背景 一次处理数据的过程中,需要将表A(源表)的数据更新到表B(目标表)中 前提 两张表一定要有关联字段 使用关联字段联查两张表时,两张表关系必须满足条件:目标表和源表的表间关系一定是多对一或者一对一 ... 
- Validation异常:No validator could be found for constraint '.....' validating type 'java.lang.Integer'.
			javax.validation.UnexpectedTypeException: HV000030: No validator could be found for constraint 'java ... 
- python HTTP请求过程
- 【NS2】How to remove Cygwin completely from Windows
			How to remove Cygwin completely from Windows 9th September 2012. 31243 views. Software Remember need ... 
- 设置WPF窗口相对于非WPF窗口的位置
			原文:设置WPF窗口相对于非WPF窗口的位置 在前一个Post当中,指出了在WPF的WindowInteropHelper类中的一个BUG:通过WindowInteropHelper的Owner属性不 ... 
