快速上手Git
本文主要摘录于廖雪峰的Git教程,个别地方做了可能不恰当的修改或补充,主要方便自己回顾。查看更详细内容请移步廖老师博客。同时,感谢廖老师写出这么好的入门指导。
(有彩蛋!!!)
一、热身
1.初始化一个Git仓库。先进入到一个本地目录下,然后使用git init命令将目录初始化。
2.添加文件到Git仓库,需要2条命令:
1)使用命令git add <file>,可反复多次使用,添加多个文件,也可一次添加多个文件。
2)使用命令git commit -m "日志内容"进行提交。
二、进入状态
1.要随时掌握工作区的状态,使用git status命令。
2.如果git status告诉你有文件被修改过,用git diff可以查看修改内容。
注:cat <file> ,是一个linux命令,表示由第一行开始显示文件内容。类似的还有tac:从最后一行开始显示;head:查看头几行;tail:查看尾几行,等等。
三、玩点高级的: 版本回溯
1.HEAD指向的版本就是当前版本,上一版本是HEAD^,每上一版本加一个^符号。使用命令“git reset --hard HEAD^”,回溯到上一版本。使用命令“git reset --hard 版本号”,回溯到具体版本。
版本号不用写全,写前4、5位就可以了。
2.用“git log <file>”查看某一文件从第一次提交到当前版本的提交历史,以便确定向前回溯到哪个版本。省略文件名,表示命令对该目录下所有文件生效。
3.用“git reflog <file>”查看某一文件的命令历史(提交、回溯),以便确定向后回溯到哪个版本。
注:当前版本不一定是最后提交的版本。
补充内容:(以下来自segmentfault用户xiaochao)
git不能把单独的某个文件恢复到指定的版本,如果要这要做,可以这样:
1)git reset 版本号,这时候,会产生一个和版本号对应的分支
2)git checkout到这个分支,把要恢复的文件拷贝走
3)git checkout到原来的分支,把文件再拷贝回来,覆盖掉现在的文件,然后git add,git commit
四、再说add与commit
1.每次修改文件后,commit之前,都要先对修改的文件进行add操作。如果不先add到暂存区,那么无法commit。
2.在某一次修改文件后,add到暂存区。然后又做了第二次修改,第二次修改后没有add操作。这样commit,只会将第一次的修改提交,第二次所做的修改不会被提交。
五、后悔药
场景1:当你误改了工作区某个文件的内容,想将文件回退到修改之前的样子时,用命令git checkout -- <file>。(注意“--”不能少)
场景2:当你误改了工作区某个文件的内容,并且将其add到了暂存区,想将文件回退到修改之前的样子时,分两步,第一步用命令git reset HEAD <file>/文件夹,这样文件就回到了工作区(即撤销add)
,第二步按场景1操作即可。
场景3:已经提交了不合适的修改到版本库时,想要撤销本次提交,参考版本回溯内容,不过前提是没有合入到远程库。如果已push到远程库,想要回溯版本。先回退本地库,再git push -f合入到远程库。(注意:本地库回溯后,版本将落后远程库,必须使用强制推送覆盖远程库,否则无法合入到远程库)
六、删除文件
1.git checkout其实是用本地版本库里的文件替换工作区/暂存区的文件,无论工作区/暂存区的文件经过修改还是删除,只要版本库中还有,都可以进行还原。还原后的文件可以回溯到任意版本。
2.命令git rm用于删除版本库中的文件。删除后并且commit,就真的从本地版本库删除了。(如果一个文件已经被提交到版本库,那么你永远不用担心在工作区和暂存区误删,但是要小心,误删之前做的修改如果没有add/commit是无法找回的。)
七、远程版本库
1.要关联一个远程版本库,使用命令git remote add origin git@server-name:path/repo-name.git。
2.关联后,使用命令git push -u origin master第一次合入master分支的所有内容到远程版本库。此后,每次本地提交后,只要有必要,就可以使用命令git push推送最新修改。如果github上的文件比本地版本库的版本新,那么push之前会提示先pull。执行git pull会进入vim让填comment,不填直接:q退出即可,然后就可以push了。
(同理:如果一个文件已经被合入到远程版本库,那么你永远不用担心在本地版本库误删,当然,这只是我目前的理解,不一定准确。)
最后彩蛋,是我绘制的一张简易的git工作流程示意图:-)
彩蛋2,推荐一本《GitHub入门与实践》,作者大塚弘记,我刚看了一半,非常好的入门书。
本作品采用知识共享署名 4.0 国际许可协议进行许可。
快速上手Git的更多相关文章
- 快速上手git gitlab协同合作
简单记录,整理. 摘要 为方便大家快速上手Git,并使用Gitlab协同合作,特编写此手册,手册内容不会太丰富与深入.主要包含如下内容: Git 使用教程1.1 安装1.2 常用命令1.3 版本控制1 ...
- Git快速上手 : Tortoise工具使用
利用工具快速上手Git 别跟我说什么用命令操作Git,多高大上呀,请不要在这里跟我装逼,就如同,有个小妞在床上眉眼诱惑地,你却TM还要先看个片儿来热热身.... TortoiseGit 名字看着眼熟 ...
- Git版本控制Windows版快速上手
说到版本控制,之前用过VSS,SVN,Git接触不久,感觉用着还行.写篇博文给大家分享一下使用Git的小经验,让大家对Git快速上手. 说白了Git就是一个控制版本的工具,其实没想象中的那么复杂,咱在 ...
- 学习Git---20分钟git快速上手
学习Git-----20分钟git快速上手 在Git如日中天的今天,不懂git都不好意思跟人说自己是程序猿.你是不是早就跃跃欲试了,只是苦于没有借口(契机). 好吧,机会就在今天. 给我20分钟,是 ...
- Rancher 快速上手指南操作(1)
Rancher 快速上手指南操作(1)该指南知道用户如何快速的部署Rancher Server 管理容器.前提是假设你的机器已经安装好docker了.1 确认 docker 的版本,下面是 ubunt ...
- [转]Rancher 快速上手指南操作(1)
本文转自:http://www.cppblog.com/zhiyewang/archive/2016/03/17/213053.aspx Rancher 快速上手指南操作(1)该指南知道用户如何快速的 ...
- Requests快速上手
发送请求 使用 Requests 发送网络请求非常简单. 一开始要导入 Requests 模块: >>> import requests 然后,尝试获取某个网页.本例子中,我们来获取 ...
- python的requests快速上手、高级用法和身份认证
https://blog.csdn.net/qq_25134989/article/details/78800209 快速上手 迫不及待了吗?本页内容为如何入门 Requests 提供了很好的指引.其 ...
- Gradle快速上手——从Maven到Gradle
[本文写作于2018年7月5日] 本文适合于有一定Maven应用基础,想快速上手Gradle的读者. 背景 Maven.Gradle都是著名的依赖管理及自动构建工具.提到依赖管理与自动构建,其重要性在 ...
随机推荐
- ?:,reverse,vector的基本小结
#include <cstdio> //此代码为网上所复制 #include <iostream> #include <string> #include <s ...
- Synchronized和java.util.concurrent.locks.Lockde区别联系
1.Lock能够完成几乎所有synchronize的功能,并且具有锁投票,定时锁,可中断等候锁,synchronize是java语言层面的,是内置的关键字,Lock是一个包,synchronize使用 ...
- hdu4044 依赖背包变形 好题!
由于不是求最大的可拦截的HP值,而是要将最小值最大化,那么就需要分配每个子树用的钱数以达到最小值最大化 第一步解决如何分配钱使得结点u的子树中用了j元钱后可以拦截的HP最大,这就是变形的分组(依赖)背 ...
- Decimal integer conversion
问题 : Decimal integer conversion 时间限制: 1 Sec 内存限制: 128 MB 题目描述 XiaoMing likes mathematics, and he is ...
- C++ GetModuleFileName()
关于GetModuleFileName function,参考:https://msdn.microsoft.com/en-us/library/windows/desktop/ms683197(v= ...
- Appium 九宫格 手势解锁
分析九宫格定位 整个九宫格是一个 view self.driver.find_element_by_id("com.elc:id/gesturepwd_create_lockview&q ...
- JS实现简单的观察者模式
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- OpenCV-Python入门教程2-打开摄像头
一.打开摄像头 import cv2 # 打开摄像头并灰度化显示 capture = cv2.VideoCapture(0) while(True): # 获取一帧 ret, frame = capt ...
- 一脸懵逼学习Nginx及其安装,Tomcat的安装
1:Nginx的相关概念知识: 1.1:反向代理: 反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到 ...
- 一脸懵逼学习Storm的搭建--(一个开源的分布式实时计算系统)
Storm的官方网址:http://storm.apache.org/index.html :集群部署的基本流程(基本套路): 集群部署的流程:下载安装包.解压安装包.修改配置文件.分发安装包.启动集 ...