参考资料:

http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000

mkdir myfirstgit    创建文件夹
cd myfirstgit     进入文件夹
git init   将当前目录初始化为Git可以管理的仓库

在文件夹下创建一个 readme.txt

git add readme.txt  把文件添加到暂存区
git commit -m "wrote a readme file"  将暂存区的内容添加到当前分支
git status  查看仓库当前状态
git diff readme.txt  查看修改的内容(本地与分支的区别)
git log  显示从最近到最远的提交日志
git reflog  显示命令历史,可以寻找想要回到的版本号
git log --pretty=oneline  日志显示在一行

ada04491a09c50f961b1922724a1b5f5dd57fca7 add haha
bb8a26a10a19e65f3b349f112915c06824002cca add haha
9f43d06753969af9e762c45b4b75ab62d4c68c7b add distributed
29a22385cad2a56a7b58f73ecd5750e773d530c4 wrote a readme file

前面的长串为版本号

git reset --hard HEAD^    回到上一个版本
git reset --hard HEAD^^  回到上上个版本
git reset --hard 9f43d06  回到这个版本号指定的版本

git checkout -- readme.txt  把readme.txt文件在工作区(本地)的修改全部撤销.
  readme.txt修改后没有放到暂存区,撤销修改就回到和版本库相同的状态。
  readme.txt已经添加到暂存区,又进行了修改,撤销修改会回到添加到暂存区后的状态。

git reset HEAD readme.txt  撤销暂存区的修改,重新放回工作区
git rm readme.txt  删除版本库中的文件
git checkout -- readme.txt  恢复工作区中的文件

====================================

git remote add origin git@server-name:path/repo-name.git  关联一个远程库(这里,server-name为github.com)
git push -u origin master  关联后,第一次推送master分支的所有内容
git push origin master 此后,每次本地提交后,推送最新修改
git clone git@github.com:USERNAME/repo-name  将远程库克隆到本地

git remote  查看远程库的信息
git remote -v  查看远程库详细信息
git checkout -b dev origin/dev  创建本地dev分支
git pull  从origin/dev抓取最新的提交,在本地合并(从而避免冲突)

注意:如果git pull提示“no tracking information”,则说明本地分支和远程分支的链接关系没有创建,用命令git branch --set-upstream branch-name origin/branch-name。

=====================================

创建&切换分支:git checkout -b dev  git checkout加上-b参数表示创建并切换,等于这两条命令:
创建分支:git branch dev
切换分支:git checkout dev

查看分支:git branch   查看当前分支
注意:在当前分支修改的不影响原来的分支

合并分支:git merge dev  将dev合并到master上,注意需要先切换到master分支再进行此操作
合并分支2 :git merge --no-ff -m "merge with no-ff" dev   采用--no-ff方式,禁用fast forword

注意:合并分支时,如果可能,Git会用Fast forward模式,但这种模式下,删除分支后,会丢掉分支信息。

   如果要强制禁用Fast forward模式,Git就会在merge时生成一个新的commit,这样,从分支历史上就可以看出分支信息。

删除分支:git branch -d dev  删除分支

分支合并图:git log --graph
分支合并图:git log --graph --pretty=oneline --abbrev-commit

=====================================

Bug分支:

保存工作现场:git stash
显示栈内备份:git stash list
恢复现场:git stash apply    恢复后,stash内容并不删除,需要用git stash drop来删除;
恢复现场2:git stash pop  恢复的同时把stash内容也删了:

=====================================

标签:

切换到需要打标签的分支

git tag v1.0  打标签
git tag  查看标签
git tag v0.9 6224937  对指定的commit id打标签
git show v1.0  查看标签信息
git tag -a v0.1 -m "version 0.1 released" 3628164  创建带说明的标签,用-a指定标签名,-m指定说明文字
git tag -s v0.2 -m "signed version 0.2 released" fec145a  通过-s用私钥签名一个标签
git tag -d v0.1  删除标签
git push origin v1.0  推送标签到远程
git push origin --tags  推送全部尚未推送的标签
删除远程标签:1、首先删除本地标签 git tag -d v0.9 
       2、然后git push origin :refs/tags/v0.9

Git学习笔记--Git常用命令的更多相关文章

  1. git学习笔记:常用命令总结

    本文根据廖雪峰的博客,记录下自己的学习笔记.主要记录常用的命令,包括仓库初始化.添加文件.提交修改.新建分支.内容暂存.分支管理.标签管理等内容. git是分布式版本控制系统. 首先是安装,从官网下载 ...

  2. Git-学习笔记(常用命令集合)

    这里引用一下百度百科里Git的内容: Git --- The stupid content tracker, 傻瓜内容跟踪器.Linus Torvalds 是这样给我们介绍 Git 的. Git 是用 ...

  3. git 学习笔记 Git实践

    网上有很多教程,这里我自己做下整理,省得有时忘记,有道是好记性不如烂博客! 先大概描述下Git的各种命令: git init                     #初始化 git clone   ...

  4. CentOS7学习笔记(四) 常用命令记录

    查看命令的帮助信息 man 命令查看帮助信息 在想要获取帮助信息的命令前面加上man即可,例如查看ls命令的帮助信息 [root@localhost ~]# man ls help 命令查看帮助信息 ...

  5. Git学习笔记 git revert

    我们难免会因为种种原因执行一些错误的commit / push,git提供了revert命令帮助程序员修复这样的错误. 举个例子,下图是git commit 的历史记录 git revert 命令会通 ...

  6. Git 学习笔记--Git下的冲突解决

    冲突的产生 很多命令都可能出现冲突,但从根本上来讲,都是merge 和 patch(应用补丁)时产生冲突. 而rebase就是重新设置基准,然后应用补丁的过程,所以也会冲突. git pull会自动m ...

  7. Git学习笔记 - Git安装

    Git安装(Windows) 从 https://git-for-windows.github.io/ 下载Git,下载完成,双击安装,一路选择默认设置即可. 注意:选择使用git的命令行模式,选择默 ...

  8. Linux学习笔记:常用命令

    个人常用的Linux命令总结(持续更新): 切换目录:cd 列出目录下面的文件:ls 显示当前所在的目录:pwd 操作文件 新建文件:touch file01 查看文件内容:less more cat ...

  9. Linux学习笔记:常用命令grep、iconv、cp、mv、rm

    本篇记录一些近期常用的命令. 一.grep过滤 grep过滤 不包含某些字符串 cat test.txt | grep -v '.jpg' 过滤jpg结尾的图片 cat test.txt | grep ...

随机推荐

  1. PHP and java

    问题补充: 为什么不选用优秀的ASP.NET,京东做的不是很成功嘛?-----------------------------------------------------------------首 ...

  2. ASP.NET 表单认证与角色授权

    参考 : http://hi.baidu.com/iykqqlpugocfnqe/item/e132329bdea22acbb6253105  ASP.NET中处理请求的流程图 http://www. ...

  3. WebBrowser执行脚本

    ExecuteJavaScript(WebBrowser:TWebBrowser; Code: string):Variant;var //发送脚本Document:IHTMLDocument2;Wi ...

  4. web前端框架选型

    1.1.界面使用脚本语言有html5,php5,css3,js动态库jquery等 1.2.html采用技术为最新html5技术,html5生成的页面在phone.pad.Phablets.pc也可方 ...

  5. 你该学点HTML/CSS知识的9大理由

    每个人都应该学写代码——这一观点简直就是铺天盖地地映入我们眼帘.或许你会莫名其妙,程序员学代码那是理所应当,但是作为一个作家.营销人员.财务工作者甚至是工人,为什么也需要学习代码呢? 好吧,下面我会告 ...

  6. 美国易安信公司 EMC

    EMC 提供了帮助您利用这一资产的工具.凭着我们的系统.软件.服务和解决方案,我们能够与您一道为您的公司打造一个综合性的信息基础架构.我们帮助客户设计.构建和管理智能.灵活而且安全的信息基础架构.这些 ...

  7. css样式-表格优化

    1.表格的初步优化 index.html <!DOCTYPE html> <html> <head> <meta charset="UTF-8&qu ...

  8. C++编程规范之12:懂得何时和如何进行并发性编程

    摘要: 如果应用程序使用了多个线程或者进程,应该知道如何尽量减少共享对象,以及如何安全地共享必须共享的对象. 在多线程和并发编程中最重要的是要避免死锁.活锁和恶性的竞争条件. 在编写多线程程序时要注意 ...

  9. ionic学习教程地址梳理

    Ionic是一个新的.可以使用HTML5构建混合移动应用的用户界面框架,它自称为是"本地与HTML5的结合".该框架提供了很多基本的移动用户界面范例,例如像列表(lists).标签 ...

  10. 【剑指Offer学习】【面试题56:链表中环的入口结点】

    题目:一个链表中包括环.怎样找出环的入口结点? 解题思路 能够用两个指针来解决问题.先定义两个指针P1和P2指向链表的头结点.假设链表中环有n个结点,指针P1在链表上向前移动n步,然后两个指针以同样的 ...