• Git两分钟指南 | 程序师【转】



    我们发布了很多Git相关的文章,有系列教程(《Pro Git系列》),也有各种独门绝技(《让你的Git水平更上一层楼的10个小贴士》)。但这篇两分钟的Git指南算是最精简的。如果想了解更多Git相关的文章,请从这里开始

    以下是Git两分钟指南的正文内容。

    受到Git五分钟指南的启发,我决定更进一步,写一篇更短时间内就能看完的Git教程。当然,这是指最简单的Git!但是对于新手个人开发者来说足够了,同时也给你提供一个可以继续深入的起点。

    能够从本指南有所收获的例子也许是这样的,一个高中生正在进行他(或是她)的第一个项目,而且并不需要和别人分享代码。(具体讲其实是我儿子,他已经写了很多代码,但是没有时间去学习一个版本控制工具。这份指南是为他写的,当然我觉得别人也能用的到。)对他来说,使用Git是很有意义的。和Subversion不同,他不需要一个服务器,就可以很容易地使用Git(只要他对硬盘进行定期备份,当然,他确实也在这么做)。正好在一个两分钟的指南中,没有时间去涉及服务器的事情,所以这篇指南对类似我儿子这种情况特别合适。

    再次强调,本文提及的Git使用方法,仅对那些会定期备份硬盘的个人开发者来讲是合适的。两分钟Git指南加上一个备份策略,你可以自信的提交文件并且知道如果自己需要的话,你可以查看改动或是恢复之前的版本。

    为什么学习Git如此有必要?好吧,对于开发者来讲,最烦人、最耗费时间的事情就发现之前可以工作的程序现在无法工作了。在这种情况下,能够看到之前的改动并且回退到之前的版本会有很大的帮助。同样的,能够回退到之前的状态可以让你自由的测试新的方法–做实验完全没有问题因为你总是可以重来。

    如果有机会的话,你绝对应该学一下暂存(staging)和分支(branching),还有向(从)远端仓库上传(pushing)和获取(pulling)。但是你下面要学到的东西同样很有用。 注意:下面提到的文件名,你都可以使用文件路径。

    使用前的设置

    如果你还没有安装git的话,请查看 Getting Started page上的安装指南。 第一次使用git,我们假定你正在一个文件夹内工作,该文件夹是你项目的主文件夹。你需要做的第一件事情是用下面这条命令来初始化文件夹供Git使用。

    git init

    告诉git你要处理的文件

    现在你需要告诉git,需要考虑哪些文件。如果你有N个文件,你可以使用

    git add <file1> <file2> … <fileN>

    来添加他们。或是你想要把目录下的文件全部添加,你可以使用

    git add . (句号是命令的一部分,表示当前目录。)

    提交改动

    下一步,我们需要提交改动。任何时候,你想要提交一个文件或多个文件的改动,运行

    git commit <file1> <file2> … <fileN> -m “This is your commit message”

    或者,提交全部有改动的文件:

    git commit -a -m “This is your commit message for all changed files”

    确保你的提交信息能够包含足够的描述信息,让你可以搞清楚你想要回退到哪个版本。

    查看历史

    现在你需要一个查看旧版本的方法。为了查看提交信息和该次提交的hash值(代表版本的一串数字)可以使用如下命令,使其以每行一个版本的方式输出

    git log –pretty=oneline

    它的输出看起来是下面这样的,每次提交的hash值和它的提交信息一起显示

    dbe28a0a1eba45d823d309cc3659069fc16297e3 4th version I wanted to commit

    13bbf385e6d1f94c7f11a4cdfa2a7688dfdd84f8 3rd

    a1696f671fb90dc8ea34645a6f851d0ab0152fc2 2nd versio

    179e59467039c7a7b81f676297415c8e018542a0 first version

    注意,你同样可以使用

    git log

    来输出一个更冗长的信息,每个版本信息占用多行,而且你可以使用

    git log –pretty=oneline — <filename>

    来查看某个具体文件的改动。(注意第二个–后面的空格!)

    恢复旧版本

    恢复之前版本的文件,你只需要使用hash值的前几个数字(要保证足够的区分度):

    git checkout <hash> — <filename>

    比如

    git checkout 179e59467039 — myfile

    会把我的名为myfile的文件的内容回退到179e59467039c7a7b81f676297415c8e018542a0这个状态(这里是指本文件的第一次提交版本)

    查看改动

    通常你不会不先查看一下文件变化就回退到旧的版本!查看文件当前版本和历史版本的区别,你需要指明历史版本的hash值:

    git diff —

    你同样可以比较两个历史版本的差别:

    git diff —

    还有一件事——可选项——也许会让本文多一分钟

    也许您仅仅使用以上功能就可以受益匪浅,你会发现还有一件事是很有用的。如果你现在不想看的话,就别看了——找机会下次再看。 有时候,你不清楚有哪些文件被改动了。你可以使用如下命令找到它们:

    git status

    这会生成一份文件列表以及他们的状态。比如,一个还没有被’git add’ 的文件会被显示为`untracked`;如果你想要追踪这个文件,就需要添加它。 在我的两分钟教程中,我把这个命令当做可选项的原因是,这个命令可能会有点笨拙。因为它可能会列出很多你并不关心的文件的状态。举例来说,如果你使用Python语言编程,它会列出Python生成的编译文件.pyc。你肯定想解决这一问题。

    为了解决这个问题,你需要在目录下创建一个叫`.gitignore` 的文件。比如你在使用Python 2.x的项目,你会希望在这个文件中(至少)包含:

    *.pyc

    注意,.gitignore` 可以理解*通配符。如果你想要隐藏一个完整的目录,你要在文件夹名后面加一个斜杠。例如你使用Python 3.x编程,所有的便以文件都会进入一个叫__pycache__ 的文件夹,所以你需要在.gitignore中添加

    __pycache__/

    这就是本教程! 把这份教程放在手边就行啦

    这些就是你开始使用git所需要知道的东西,只要你有定期备份硬盘的习惯。如果你不想要记忆除了提交命令以外的其他东西,仅需要把本教程保存进书签,你就可以无障碍的提交,对比版本,回退到旧版本! 记住,本教程准确来讲是最小化教程,让你可以用Git做一些有用的事情。对于分支,暂存和通过远程服务器和他人共享代码这些强大的功能,请务必去看五分钟Git教程,如果有机会甚至应该去看更长的教程! 





  • 相关阅读:
    关于linux命令 cp,rm,mv执行时是否询问的问题,不同用户有不同的别名设置
    用jquery根据json动态创建多级菜单导航(by https://www.cnblogs.com/fatty-yu/p/7088955.html)
    前台向后台传值的两种方法 以及 从后台获取数据的方法
    “加载更多”功能如何实现
    AngularJS的主要组成部分:
    数组与字符串的相互转化
    angular过滤器的使用 By http://www.tuicool.com/articles/ueUZBv
    transclude
    内嵌模版 template 原创
    导航栏选中效果 ng-repeat
  • 原文地址:https://www.cnblogs.com/pyld/p/4716768.html
Copyright © 2020-2023  润新知