码迷,mamicode.com
首页 > 其他好文 > 详细

GIT使用教程——命令详解

时间:2017-12-20 20:07:23      阅读:147      评论:0      收藏:0      [点我收藏+]

标签:modified   标签   ast   图片   bsp   stream   git pull   分享图片   com   

技术分享图片

$ 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使用教程——命令详解

标签:modified   标签   ast   图片   bsp   stream   git pull   分享图片   com   

原文地址:http://www.cnblogs.com/heling-android/p/8058472.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!