`
love~ruby+rails
  • 浏览: 857261 次
  • 性别: Icon_minigender_1
  • 来自: lanzhou
社区版块
存档分类
最新评论

git is great 2

阅读更多

Git梳妆
我们可以利用Git的config命令或者直接编辑~/.gitconfig文件(如果没有的话创建它)来为自己打造独一无二的Git。我建议直接编辑用户目录下得.gitconfig文件,拿我本地的文件为例,一一为大家解说,完整的文件内容如下:

[user]
    name = Phoenix
    email = phoenixtoday@gmail.com
[alias]
  co = checkout
  ci = commit -a
  st = status
  br = branch
  oneline = log --pretty=oneline --since='2 days ago'
  onelog = log -p -1
[color]
  status = auto
  branch = auto
  ui = auto

该文件主要包含三个部分的内容:

  • 用户基本信息:可以设置你的名字和email,这样在你提交代码的时候就会显示出你的名字
  • 命令别名:这是.gitconfig文件中,我最喜欢的部分,它可以大大减少你敲击键盘的次数(俗话说优秀的程序员都很懒么)。在该文件中,我将co设置为checkout的别名,那么下次我只要用'git co new_branch'就可以切换到new_branch分支下了,简洁而优雅;将ci设置为commit -a的别名,-a选项表示我不需要将修改和删除的文件通过'git add'命令来加入索引,这样设置在使用'git ci -m"message"'这样的命令时,相当于连续执行了'git add 被修改和删除的文件'和'git commit -m"message"'两条命令,再一次节省了我们宝贵的时间;最酷的是最后两行,后面的章节会一一介绍。Git提供许多优雅、人性化的选项,我们如果再结合别名的设置,可以发挥你最大的想象力,真的让你自己的Git活起来
  • 颜色:每次看diff时是不是挺痛苦的?那么为什么不给我们的Git加上颜色呢?只需要加上那三行,就可以让红色和绿色的提示出现在你的控制台中


Git灵动
现在来讲讲'git log','git stash','git formate-patch'三个命令的用法和技巧:

  • git log:不同于SVN,Git将代码的历史记录全部在本地克隆了一份,所以这就使得'git log'这样的命令使用起来非常的迅速,也是我最常使用的Git命令之一。在使用'git log'的时候,你可以加入很多的后缀。'-p'表示查看修改的具体内容,例如'git log -p'它不但会打印出提交的时间、版本号、人员等,还会将具体的代码修改部分打印出来;'-n'其中n表示一个数字,这表示打印出具体的几个日志,例如 'git -p -1'正如我的Git配置文件中设置的onelog别名的内容一样,就表示打印出当前最新的一次日志记录及具体修改内容;'--since="时间/日期"','--until="时间/日期"'表示你希望查找某个日期段的日志记录,例如'git log --since="2 days ago" --until="1 hour ago"'就表示你希望查找两天前到一小时前的日志记录,Git是足够聪明的,它可以将类似于'2 days ago'和'1 hour ago'这种表示时间的英语转化为具体的时间数字;有的时候,你不希望翻很多页才可以看到所有的日志,你只希望看到简短的说明,那么Git为你提供打印格式的定制'git --pretty=格式种类',其中格式种类有full、short、oneline等,例如'git log pretty=oneline'就会将每条代码历史记录放在一行里,看起来简单明了
  • git stash:在第一篇中,我举了一个使用branch解决紧急任务切换的问题,其实stash命令也可以很好的解决这样的问题。当你不想提交当前完成了一半的代码,但是却不得不修改一个紧急Bug,那么使用'git stash'就可以将你当前未提交到本地(和服务器)的代码推入到Git的栈中,这时候你的工作区间和上一次提交的内容是完全一样的,所以你可以放心的修 Bug,等到修完Bug,提交到服务器上后,再使用'git stash apply'将以前一半的工作应用回来。也许有的人会说,那我可不可以多次将未提交的代码压入到栈中?答案是可以的。当你多次使用'git stash'命令后,你的栈里将充满了未提交的代码,这时候你会对将哪个版本应用回来有些困惑,'git stash list'命令可以将当前的Git栈信息打印出来,你只需要将找到对应的版本号,例如使用'git stash apply stash@{1}'就可以将你指定版本号为stash@{1}的工作取出来,当你将所有的栈都应用回来的时候,可以使用'git stash clear'来将栈清空
  • git format-patch:当你想给一个开源项目(例如Rails)提交一段代码的时候,或者你想给小组成员展示一段你并不想提交的代码,那么你还是需要 patch的,Git的'format-patch'命令良好的支持了这个功能。我来基本描述一下使用这个命令的步骤和方法:第一,利用branch命令创建一个分支;第二,修改你的代码;第三,在该分支上提交你的修改;第四,使用'git format-patch'命令来生成一个patch文件,例如:'git format-patch master --stdout > ~/Desktop/tmp.patch'就是将工作分支与master主干的不同,存放在'~/Desktop'文件夹下,生成一个叫做 tmp.patch的文件(另一种简单的版本是利用diff命令,例如'git diff ..master > ~/Desktop/tmp.patch'),这样就生成了patch文件。那么别人就可以使用'git apply'命令来应用patch,例如'git apply ~/Desktop/tmp.patch'就是将patch打在当前的工作分支上


Git亲友团
Git的使用技巧还包括利用Git包含的和附加的一些强大工具,这些工具主要包括git svn、git citool、gitk和Git的自动提示脚本:

  • git svn:Git和SVN可以很方便的集成在一起,这就大大减少了从SVN向Git迁移的学习成本,这也是我特别建议大家首次接触Git的使用方式。git svn是一个Git内置的工具,你安装了Git也就安装了它,譬如说你们团队有一个SVN服务器,但是你想利用Git本地的一些强大特性,那么你依然可以安装Git,使用Git的branch功能,只不过再更新代码和提交代码的时候,使用git svn命令即可。在这里我简单的讲讲最常使用和需要注意的两个命令,其余的命令读者可以通过'git svn --help'来查看:'git svn rebase'命令取代了'svn update'用于将服务器代码更新到本地;'git svn dcommit'取代了'svn ci',需要注意的是,本地必须用Git提交了代码之后,再使用'git svn dcommit'。只需要这样,你就可以轻松地从SVN转向Git了。
  • git citool:这是我个人使用率最频繁的一个工具,上一篇文章也提到了,Git可以本地提交代码,那么你自然可以本地修改你的提交了,这个工具就是可视化界面,用于修改你本地的提交。只要在你的工作区间输入'git citool',就会出现如下的界面

         你可以用它来提交代码,可以用它来将你本地的修改追加在上一次提交的代码中,你还可以用它来修改你上次提交的信息等等。这个工具可以大大帮助你完成以前SVN不可能完成的任务

  • gitk:是一个查看主干/分支情况的工具,它主要用于观察整个项目的分支状况,使用'gitk'命令就会出现一个图形化界面供你查看,本篇就简单的说一下,大家回去试试就知道了
  • Git 的自动提示脚本:它是Shawn O. Pearce为了让Git使用起来更方便而写得Shell脚本,你可以在http://gitweb.hawaga.org.uk/ 找到一个叫做gitcompletion的脚本,下载下来,并按照该脚本中指导的方式进行配置,你就具有了Git自动提示(敲入部分Git命令,再按 Tab键)的功能,而且有了这个脚本,你也可以看到你当前工作在哪个branch下。惟一的不足是,它只支持Linux、Unix、Mac操作系统(推荐大家都用Mac进行开发)

Git实战─Git Hub
经过这么长时间理论知识的熏陶,想必大家早已跃跃欲试了,那么我们在Git Hub上建立一个开源项目作为实战演习吧。Git Hub是全球最大的Git服务器供应商,每个帐号有100M的免费使用空间,网址是:https://github.com/
  • 首先我们在Git Hub上创建一个帐号,按照上面指导的方法设置好你的认证信息(每次提交代码都会需要这个认证信息)
  • 然后,如下图新建一个项目(选择Create a New Repository),名叫git usage
  • 在服务器端,你可以看到这个项目的信息,包括项目源代码的URL,如下图
  • 在本地使用如下的命令,就可以完成你的第一次提交了:

    mkdir git-usage(创建项目目录)
    cd git-usage(进入项目目录)
   git init(Git初始化)
   touch README(创建一个README文件)
    git add README(增加该文件到索引)
    git commit -m 'first commit'(本地提交)
    git remote add origin git@github.com:phoenixtoday/git-usage.git(增加远程服务器代码库地址)
    git push origin master(将本地代码提交到远程服务器上)
总结

我所在的项目小组自从使用Git后,发现Git提供的种种特性大大提高了我们的开发效率,在认识Git前我们无法想象一个版本控制工具可以让开发任务切换变得如此自然流畅。所以我强烈推荐大家使用Git,你付出的学习绝对物有所值

分享到:
评论

相关推荐

    painless_git.pdf

    You get great advice about rebasing instead of merging, which is a good idea except for those times where it's a bad idea. Stray too far into the weeds and you start hearing about "reflog" which ...

    Greatis Ultimate Pack.2009.10.8.rar

    《Greatis Ultimate Pack.2009.10.8.rar》是一款集合了大量Delphi开发工具和资源的压缩包,发布于2009年10月8日。这个包对于Delphi开发者来说,是一个宝贵的资源库,包含了各种实用的组件、库和插件,旨在提升开发...

    progit-en.935

    The first edition of this book is what got me hooked on Git. This was my introduction to a style of making software that felt more natural than anything I had seen before. I had been a developer for ...

    Android代码-Android

    Github is great. To get the most recent files, execute this: git pull origin master Please don't push code to this repo unless you find something blatantly wrong with my code. In that case, please do...

    GitLab Cookbook

    This book will also be useful for people looking for a great Git platform, and learn how to set it up successfully. Some system administrating experience on a UNIX-based system would be useful, but ...

    autocomplete-redis 是一个基于 redis 的类似 quora 的自动完成功能 .zip

    autocomplete-redis 是一个...items=[{"uid":'1', "score":9, "term": u"hello world, that's great"}, {"uid":'2', "score":10, "term": u"what the hell or yell"}, {"uid":'3', "score":8.5, "term":u"World is l

    Drupal.8.for.Absolute.Beginners.1430264667

    The book also is great for the business community trying to understand the power of open source. It’s important as a business person to know what tools are available to solve problems. The Drupal ...

    PHP Objects, Patterns, and Practice, 4th Edition

    The last segment of the book covers the tools and practices that can help turn great code into a successful project. The section shows how to manage multiple developers and releases with git, how to ...

    race:Attempto Reasoner RACE的SOAP接口的Prolog客户端

    图书馆(种族) 的SOAP接口的Prolog客户端。安装该软件包需要 。 可以使用以下命令从安装它: ?...- check_consistency("John is great. He is not great.").false .%% check_consistency(+Knowledge, -Inc

    Orchard CMS Up and Running

    The BSD license under which Orchard is distributed is a permissive free software license, offering great flexibility in how the software can be used, modified, and redistributed. This licensing choice...

    sympy-docs-pdf-1.0.pdf

    #### 2. SymPy Tutorial The tutorial section provides a comprehensive guide on how to use SymPy effectively. ##### 2.1 Preliminaries Before diving into the details, it's essential to understand some...

    Learning Web Design: A Beginner’s Guide to HTML... ..., 5th Edition

    Become familiar with the command line, Git, and other tools in the modern web developer’s toolkit NEW! Get to know the super-powers of SVG graphics Partl. Getting Started 1. Getting Started in Web ...

    android-viewflow

    GitHub has some great articles on how to get started with Git and GitHub and how to fork a project. Contributers are recommended to fork the app on GitHub (but don't have too). Create a feature ...

    This tool is for those who often want to search for a string deeply into a directory in recursive mode, but not with the great tool: grep, ack, ripgrep .........一个工具最大的价值不是它有多少功能,而是它能够让你以多快的速度达成所愿......

    下载文件git clone https://github.com/Lispre/so_stupid_search.git3.进入包含名称为“Cargo.toml”的文件的目录并运行命令为blow:cd so_stupid_searchcargo build --release4.然后你会得到可执行文件“so_stupid_...

    PHP Objects, Patterns, and Practice(Apress,2016)

    The last segment of the book covers the tools and practices that can help turn great code into a successful project. The section shows how to manage multiple developers and releases with git, how to ...

    OpenCV with Python

    It has some great stuff in there that everyone should know (classification, regression, decision trees, SVMs, etc.) and beyond. It uses OpenCV, some Scikit learn and Keras. Python only! === 5.0 颗星...

    Spring.MVC.Cookbook.1784396419

    Spring MVC is a lightweight application framework that comes with a great configuration by default. Being part of the Spring Framework, it naturally extended and supported it with an amazing set of ...

    Twitter-with-Frontend:具有前端的Twitter克隆

    推文可以包含主题标签(例如,#COP5615isgreat)和提及(@bestuser) 订阅用户的推文 重新发送推文(以便您的订阅者获得通过其他方式获得的有趣推文) 允许查询已订阅的推文,具有特定主题标签的推文,提及用户...

Global site tag (gtag.js) - Google Analytics