GIT使用教程——命令详解
$ git init 当前目录建立GIT可以管理的仓库(版本库),生成一个.git的隐藏文件夹
$ git add <filename> 将工作区的文件修改添加到版本库的暂存区
$ git commit -m "tips" 将暂存区的所有修改添加到分支上,tips是本次提交的备注,方便查看
$ git status 本地工作区与分支的代码比较,工作区文件与版本库比较的状态
(modified 文件被修改 ; deleted 工作区文件被删除 ; Untracked 文件未跟踪,版本库没有 ; new file 文件add到暂存区,还未添加到分支 )
$ git diff <filename> 比较工作区和版本库的文件,文件内容具体哪些不同
$ git log 版本库状态信息,git commit的记录信息,便于跟踪提交每次都有哪些修改
$ git reset --hard <版本号> 版本库回退到某个版本的状态
$ git reset --hard HEAD^ 回退到当前版本的上一个版本,撤销上次的提交,HEAD指向当前版本的指针
$ git reflog 记录你的每一次git命令,便于跟踪
$ git checkout --<filename> 工作区的文件回退到最近一次add或commit时的状态,删除掉的文件也可还原回来
$ git reset HEAD <filename> 撤销暂存区的文件的修改,然后再checkout撤销工作区的修改
$ git rm <filename> 将删除消息提交到暂存区,commit后版本库的文件会被删除
$ git checkout -b <name> 创建新的分支name,-b会将当前工作分支切换到dev,相当于下面两条命令
$ git branch <name> 创建新的分支name
$ git checkout <name> 切换当前工作分支为name
$ git branch 查看所有分支,前面带*号,表明是当前所在分支
$ git merge <name> 合并name分支到当前分支
$ git branch -d <name> 删除分支name
$ git log --graph 查看分支合并图
$ git stash 保存当前分支工作现场
$ git stash pop 恢复保存的工作现场
$ git branch -D <name> 强行删除分支(丢弃分支的所有提交)
$ git remote -v 查看远程库信息
$ git pull 抓取远程的新的提交(推送前最好先pull一下,免得覆盖别人的代码)
$ git push origin branch-name 从本地推送分支
$ git checkout -b branch-name origin/branch-name在本地创建远程分支对应的分支
$ git brach --set-upstream branch-name origin/branch-name建立本地分支和远程分支关联
$ git tag <name> 在当前分支打一个标签
$ git tag 查看所有标签
$ git tag -a <tagname> -m "balabala" 指定标签信息
$ git tag -s <tagname> -m "balabala" 用PGP签名标签
$ git tag -d <tagname> 删除一个本地的标签
$ git push origin <tagname> 推送一个本地标签到远程分支
$ git push origin --tags 推送全部未推送过的本地标签
$ git push origin : refs/tags/<tagname>删除一个远程标签
<<<<<<<<<<<<<<<<<OVER>>>>>>>>>>>>>>>>>>>>>>>>>
HEAD指针严格来说不是指向提交的,而是指向master主分支的,每一次提交主分支就多一个节点,master指向最新提交,HEAD指向master,就能确定当前分支为主分支和当前分支的最新提交节点。
当我们创建分支dev时,GIT创建一个dev的指针,指向master相同的提交,再把HEAD指向dev,表示当前工作节点在dev分支上。当我们在dev分支提交时,dev指向新的提交(红色节点),master指针不变,这样就确保了两个分支能同时存在,HEAD指向工作区当前在哪个分支上工作。
当我们要合并两个分支时,就需要将两个分支的提交内容合并,当主分支没有新的提交时,只需要将master分支指向dev指向的提交节点,即可完成合并,但当两个分支都有各自不同的提交时,GIT小心的合并各自提交的修改,遇到冲突(即两个分支提交都对同一个文件修改)时,需要人工去解决冲突(人工合并文件)。
GIT使用教程——命令详解的更多相关文章
- Windows系统Git安装教程(详解Git安装过程)
Windows系统Git安装教程(详解Git安装过程) 今天更换电脑系统,需要重新安装Git,正好做个记录,希望对第一次使用的博友能有所帮助! 获取Git安装程序 到Git官网下载,网站地址: ...
- Git入门教程,详解Git文件的四大状态
大家好,欢迎来到周一git专题. git clone 在上一篇文章当中我们聊了怎么在github当中创建一个属于自己的项目(repository),简称repo.除了建立自己的repo之外,我们更多的 ...
- git push&pull命令详解
git pull的作用是从一个仓库或者本地的分支拉取并且整合代码. git pull [<options>] [<repository> [<refspec>-] ...
- Git的使用以及常用命令(详解)
一. 版本控制工具 什么是版本控制系统? 版本控制系统(Version Control System):是一种记录一个或若干文件内容变化,以便将来查阅特定版 本修订情况的系统.版本控制系统不仅可以应用 ...
- Git初探--笔记整理和Git命令详解
几个重要的概念 首先先明确几个概念: WorkPlace : 工作区 Index: 暂存区 Repository: 本地仓库/版本库 Remote: 远程仓库 当在Remote(如Github)上面c ...
- Git 常用命令详解
Git 是一个很强大的分布式版本管理工具,它不但适用于管理大型开源软件的源代码(如:linux kernel),管理私人的文档和源代码也有很多优势(如:wsi-lgame-pro) Git 的更多介绍 ...
- Android Studio系列教程五--Gradle命令详解与导入第三方包
Android Studio系列教程五--Gradle命令详解与导入第三方包 2015 年 01 月 05 日 DevTools 本文为个人原创,欢迎转载,但请务必在明显位置注明出处!http://s ...
- Git 常用命令详解(二)
Git 是一个很强大的分布式版本管理工具,它不但适用于管理大型开源软件的源代码(如:linux kernel),管理私人的文档和源代码也有很多优势(如:wsi-lgame-pro) Git 的更多介绍 ...
- Git命令详解
一个中文git手册:http://progit.org/book/zh/ 原文:http://blog.csdn.net/sunboy_2050/article/details/7529841 前面两 ...
随机推荐
- samba对外开放的端口
前言搭建samba的时候,如果是在内网\测试环境中,可以直接关闭防火墙,但是如果是在外网情况下,需要对防火墙开放某些端口.开放的具体步骤,下面我们来看. 操作步骤1.添加端口 firewall-cmd ...
- zookeeper集群搭建记录
本文仅记录zookeeper集群搭建的过程,留待日后查看.使用. 一.硬件机器: 192.168.183.195 master-node 192.168.183.194 data-node1 192. ...
- 洛谷 P1494 [国家集训队]小Z的袜子(莫队)
题目链接:https://www.luogu.com.cn/problem/P1494 一道很经典的莫队模板题,然而每道莫队题的大体轮廓都差不多. 首先莫队是一种基于分块的算法,它的显著特点就是: 能 ...
- Python学习之面向对象进阶
面向对象进阶当然是要谈谈面向对象的三大特性:封装.继承.多态 @property装饰器 python虽然不建议把属性和方法都设为私有的,但是完全暴露给外界也不好,这样,我们给属性赋值的有效性九无法保证 ...
- Python学习之字典集合篇
lambda表达式:起到一个函数速写的作用,允许在代码内嵌入一个函数的定义; filter()函数:1.用于过滤序列,过滤掉不符合条件的元素,返回由符合条件元素组成的新列表.2.接收两个参数,第一个为 ...
- mysql之mysql的安装
此次MySQL安装的版本为:MySQL8.0 系统为:centos6.9 64位 一.利用yum仓库安装 wget https://repo.mysql.com//mysql80-community- ...
- python练习:斐波那契数列的递归实现
python练习:斐波那契数列的递归实现 重难点:递归的是实现 def fib(n): if n==0 or n==1: return 1 else: return fib(n-1)+fib(n-2) ...
- LeetCode练题——66. Plus one
1.题目 66. Plus One——easy Given a non-empty array of digits representing a non-negative integer, plus ...
- 基础_04_list and tuple
一.list(列表) list是Python里的一种容器,里面可以存储多个任何类型的数据,长度也可以任意伸缩,可以像C语言中数组那样,按照索引下标获取对应的值.但数组是一个存储多个固定类型变量的连续内 ...
- java模板字符串功能的简单实现
package com.Interface.util; import lombok.extern.slf4j.Slf4j; /** * 测试类 * * @author 华文 * @date 2019年 ...