GitHub---Git基本概念篇

如何使用git命令上传本地到github?

本系列教程主要参考github用户stormzhang,涉及到Github中基本概念,Git速成,向 GitHub 提交代码,Git 进阶, 团队合作利器:Git 分支详解, GitHub 常见的几种操作。
如果想快速学习使用git命令上传本地到github可以参考如下博客。
如何用git命令行上传本地代码到github

git_learn.jpg

GitHub 基本概念

  • Repository
    仓库,即你的项目,你想在GitHub上开源一个项目,那就必须要新建一个Repository,如果你开源的项目多了,你就拥有了多个Repositories。
  • Issue
    问题,举个例子,就是你开源了一个项目,别人发现你的项目中有bug,或者哪些地方做的不够好,他就可以给你提个Issue,即问题,提的问题多了,也就是Issues,然后你看到了这些问题就可以去逐个修复,修复ok了就可以一个个Close掉。
  • Star
    这个好理解,就是给项目点赞,但是在GitHub上的点赞远比微博、知乎点赞难的多,如果你有一个项目获得100个star都算很不容易了!
  • Fork
    这个不好翻译,如果实在要翻译我把他翻译成分叉,什么意思呢?你开源了一个项目,别人想在你这个项目的基础上做些改进,然后应用到自己的项目中,这个时候他就可以 Fork 你的项目,这个时候他的GitHub主页上就多了一个项目,只不过这个项目是基于你的项目基础(本质上是在原有项目的基础上新建了一个分支,分支的概念后面会在讲解Git的时候说到),他就可以随心所欲的去改进,但是丝毫不会影响原有项目的代码与结构。
  • Pull Request
    发起请求,这个其实是基于Fork的,还是上面那个例子,如果别人在你基础上做了改进,后来觉得改进的很不错,应该要把这些改进让更多的人收益,于是就想把自己的改进合并到原有项目里,这个时候他就可以发起一个Pull Request(简称PR) ,原有项目创建人就可以收到这个请求,这个时候他会仔细review你的代码,并且测试觉得OK了,就会接受你的PR,这个时候你做的改进原有项目就会拥有了。
  • Watch
    观察,如果你Watch了某个项目,那么以后只要这个项目有任何更新,你都会第一时间收到关于这个项目的通知提醒。
  • Gist
    有些时候你没有项目可以开源,只是单纯的想分享一些代码片段,那这个时候Gist就派上用场了!

Git速成

  1. 什么是Git?
    Git 是 Linux 发明者 Linus 开发的一款新时代的版本控制系统,那什么是版本控制系统呢?怎么理解?网上一大堆详细的介绍,但是大多枯燥乏味,对于新手也很难理解,这里我只举几个例子来帮助你们理解。
    熟悉编程的知道,我们在软件开发中源代码其实是最重要的,那么对源代码的管理变得异常重要:
    比如为了防止代码的丢失,肯定本地机器与远程服务器都要存放一份,而且还需要有一套机制让本地可以跟远程同步;
    又比如我们经常是好几个人做同一个项目,都要对一份代码做更改,这个时候需要大家互不影响,又需要各自可以同步别人的代码;
    又比如我们开发的时候免不了有bug,有时候刚发布的功能就出现了严重的bug,这个时候需要紧急对代码进行还原;
    又比如随着我们版本迭代的功能越来越多,但是我们需要清楚的知道历史每一个版本的代码更改记录,甚至知道每个人历史提交代码的情况;
    等等等类似以上的情况,这些都是版本控制系统能解决的问题。所以说,版本控制是一种记录一个或若干文件内容变化,以便将来查阅特定版本修订情况的系统,对于软件开发领域来说版本控制是最重要的一环,而Git毫无疑问是当下最流行、最好用的版本控制系统。
  2. Git安装
    Mac: https://sourceforge.net/projects/git-osx-installer/
    Windows: https://git-for-windows.github.io/
    Linux: apt-get install git
  3. Git命令列表
    git_common_usage.png
  4. Git具体命令
    第一步,我们先新建一个文件夹,在文件夹里新建一个文件(本文所有操作均基于Linux命令,Windows用户可以自己手动新建)
mkdir git_learn                 (创建文件夹git_learn)
cd     git_learn                (切换到git_learn目录)
touch    git.md                   (新建git.md文件)

注:在进行任何Git操作之前,都要先切换到Git 仓库目录下,也就是先要先切换到项目的文件夹目录下。

这个时候我们先随便操作一个命令,比如 git status,可以看到如下提示(别纠结颜色之类的,配置与主题不一样而已):
non_git_repository.png
  • git init 初始化 git 仓库
  • git status
    git_status.png

    git status 这个命令顾名思义就是查看状态,这个命令可以算是使用最频繁的一个命令了,建议大家没事就输入下这个命令,来查看你当前 git 仓库的一些状态。
    默认就直接在master分支,关于分支的概念后面会提,这时最主要的是提示 git.md 文件Untracked files,就是说git.md这个文件还没有被跟踪,还没有提交在 git 仓库里呢,而且提示你可以使用git add 去操作你想要提交的文件。

  • git add

    上面提示 git.md 文件还没有提交到 git 仓库里,这个时候我们可以随便编辑下 git.md 文件,然后输入 git add git.md, 然后再输入git status:
    git_add_status.png
    此时提示以下文件Changes to be committed, 意思就是a.md文件等待被提交,当然你可以使用git rm --cached 这个命令去移除这个缓存。
  • git commit
    接着我们输入git commit -m 'first commit',这个命令什么意思呢? commit 是提交的意思, -m代表是提交信息,执行了以上命令代表我们已经正式进行了第一次提交。
    这个时候再输入git status,会提示nothing to commit。
    git_commit.png
    注意:安装好git后,在命令行或终端中使用下面的命令可以设置git自己的名字和电子邮件。这是因为Git是分布式版本控制系统,所以,每个机器都必须自报家门:你的名字和Email地址。git config命令的–global参数,用了这个参数,表示你这台机器上所有的Git仓库都会使用这个配置,当然也可以对某个仓库指定不同的用户名和Email地址。配置好之后可以使用git config -l查看配置。
  • git log 查看所有commit记录
  • git add & git commit
    看到这里估计很多人会有疑问,我想要提交直接进行 commit不就行了么,为什么先要再add一次呢?首先 git add 是先把改动添加到一个[暂存区],你可以理解成是一个缓存区域,临时保存你的改动,而git commit才是最后真正的提交。这样做的好处就是防止误提交,当然也有办法把这两步合并成一步,不过后面再介绍,建议新手先按部就班的一步步来。
  • git branch 查看、创建(git branch name)分支
    branch即分支的意思,分支的概念很重要,尤其是团队协作的时候,假设两个人都在做同一个项目,这个时候分支就是保证两人能协同合作的最大利器了。举个例子,A, B俩人都在做同一个项目,但是不同的模块,这个时候A新建了一个分支叫a, B新建了一个分支叫b,这样A、B做的所有代码改动都各自在各自的分支,互不影响,等到俩人都把各自的模块都做完了,最后再统一把分支合并起来。
    执行 git init 初始化git仓库之后会默认生成一个主分支 master,也是你所在的默认分支,也基本是实际开发正式环境下的分支,一般情况下 master 分支不会轻易直接在上面操作的,你们可以输入git branch 查看下当前分支情况:
    如果我们想在此基础上新建一个分支呢,很简单,执行 git branch a就新建了一个名字叫 a 的分支,这时候分支a跟分支master是一模一样的内容,git checkout a可以切换到分之a。git checkout -b a表示新建分支a,并直接切换。
  • git merge 合并分支
    合并分之分两步:第一步是切换到 master分支,如果你已经在了就不用切换了,第二步执行git merge a,意思就是把a分支的代码合并过来,不出意外,这个时候a分支的代码就顺利合并到 master 分支来了。为什么说不出意外呢?因为这个时候可能会有冲突而合并失败,留个包袱,这个到后面进阶的时候再讲。
  • git branch -d a 删除分支a
  • git branch -D a 强制删除分支a
  • git tag 查看历史tag记录
    git tag v1.0表示给代码打上版本标签,git checkout v1.0 ,切换到v1.0tag的代码状态了。

本系列内容转载总结自原创作者stormzhang,其
个人博客: http://stormzhang.com
GitHub: https://github.com/stormzhang
知乎: stormzhang
微博: googdev

你可能感兴趣的:(GitHub---Git基本概念篇)