博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Git 两分钟指南
阅读量:6618 次
发布时间:2019-06-25

本文共 2612 字,大约阅读时间需要 8 分钟。

Git 两分钟指南

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

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

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

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

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

使用前的设置

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

 
  1. git init

告诉git你要处理的文件

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

 
  1. git add <file1> <file2> <fileN>

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

 
  1. git add .

句号是命令的一部分,表示当前目录。

提交改动

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

 
  1. git commit <file1> <file2> <fileN> -m This is your commit message

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

 
  1. git commit -a -m This is your commit message for all changed files

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

查看历史

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

 
  1. git log --pretty=oneline

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

 
  1. dbe28a0a1eba45d823d309cc3659069fc16297e3 4th version I wanted to commit
  2. 13bbf385e6d1f94c7f11a4cdfa2a7688dfdd84f8 3rd
  3. a1696f671fb90dc8ea34645a6f851d0ab0152fc2 2nd versio
  4. 179e59467039c7a7b81f676297415c8e018542a0 first version

注意,你同样可以使用

 
  1. git log

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

 
  1. git log --pretty=oneline -- <filename>

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

恢复旧版本

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

 
  1. git checkout <hash> -- <filename>

比如

 
  1. git checkout 179e59467039 -- myfile

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

查看改动

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

 
  1. git diff <hash> -- <filename>

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

 
  1. git diff <hash1> <hash2> -- <filename>

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

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

 
  1. git status

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

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

 
  1. *.pyc

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

 
  1. __pycache__/
原文发布时间:2015-01-19
本文来自云栖合作伙伴“linux中国”

转载地址:http://bnypo.baihongyu.com/

你可能感兴趣的文章
QuickBI助你成为分析师——数据源FAQ小结
查看>>
十周三次课
查看>>
2008 AD 复制有防火墙要开什么端口
查看>>
我的友情链接
查看>>
敏友的【敏捷个人】有感(11): 敏捷个人线下活动有感
查看>>
刺激用户危机意识,实现快速盈利的营销思维
查看>>
JUnit单元测试
查看>>
[logstash-input-file]插件使用详解
查看>>
植物大战僵尸
查看>>
原创文章
查看>>
理解JavaScript私有作用域
查看>>
BZOJ 1012: [JSOI2008]最大数maxnumber【线段树单点更新求最值,单调队列,多解】
查看>>
Drupal 7模板(主题钩子)的建议
查看>>
nginx配置文件中location说明
查看>>
连载-第1章绪论 1.1嵌入式系统概述
查看>>
UltraVNC
查看>>
详解synchronized
查看>>
Spring Cloud第二篇 创建一个Eureka Server
查看>>
初探数据双向绑定
查看>>
Webpack4 不深不浅的实践教程
查看>>