git学习总结

当我学习一个新东西的时候,习惯于把它看成一种解决方案.而在每一种解决方案的背后,都会存在一个或多个问题.而整个学习过程就是在寻找,明确这些问题.

为什么会有git

git本身作为一个解决方案,肯定存在与之相对应的问题.
学完之后发现git解决两个问题.

  • 做有些事情时候很少有人能够从头到尾一气呵成.需反复地修改才能完成.为了让修改工作更加高效,记录历史信息就非常有必要了.(在软件开发领域,把记录历史这一件事情叫做版本控制)
  • 如果两个人要合作做一件事情,那么在合作中会出现的一些问题git可以帮助他们解决.

解决方案的两种形式

目前的解决方案主要分为两种

集中式

其代表为svn

通过将修改的内容统一提交到远程服务器,由远程服务器来记录每一次提交历史信息.每一次提交就相当于创建一个恢复点.在未来的某个时刻,可以直接恢复到以前的某一个提交之后的状态.

svn通过分支功能来辅助参与者相互协作.在完成一个产品的时候给每一个参与者创建一个分支(类似于一个副本,当然这里不可能是一个完全的copy,只是一个指向主分支的一个指针).然后每一个参与者都是在自己的分支上完成相应工作,最终合并到主分支.以此来达成协作.

分布式

其代表为git

通过将修改的内容提交到本地服务器,由本地服务器来记录每一次修改的历史信息.好处在于不用联网就可以达到记录历史信息的目的.

git同样是通过分支功能来达成协作的.不同的是,因为是分布式的,所以每一个参与者都有一个完整的备份,安全性更高.而且git有一个非常大的优势,在于它有一个全球公用的服务器(github),可以实现全球范围内的协作.

如何使用git

几个新概念

Paste_Image.png
  1. Working Directory(工作区)
    就是一个工作目录,文件的修改内容最开始是保存在这里的,如上图.
  2. Repository(版本库)
    为.git文件夹
  3. Stage(暂存区)
    一个为了优化使用体验而设计的一个存储区域,位于.git文件夹内部.比如你有A-J总共10个要提交的文件,但是文件A,D,H为相关文件要一次性提交,如果等10个文件全部编辑完后直接提交的话操作起来比较麻烦.如果用stage的话,可以在完成每一个文件后将其add到stage中.之后,就可以一次性提交了.


    git_add.png

    git_commit.png
  4. 分支
    分支只是一个形象的描述.每当新建一个分支的时候实际上只是新建了一个指针.然后由这个指针跟踪的若干提交共同组成了一个分支.


    new_branch.png

git针对记录历史信息提供的解决方案有:

  1. 查看当前版本库的状态,提交修改
git status
--将修改提交到stage
git add file
--将修改从stage提交到版本库
git commit file
  1. 可以退回到之前的某一次提交.
git reset --hard  commit_id
  1. 用暂存区提供(新增,撤销,提交)每一次修改(包括增,删,改)的功能.
--将修改退回到stage,或者上一次提交的状态.
git checkout -- file
--将stage中的内容退回到上次提交时的状态.
git reset HEAD file
--删除版本库中的文件
git rm file
  1. 可以对比当前版本与之前版本的异同.
--各种异同对比,分支,文件,工作区和暂存区
git diff

git针对辅助协作提够的解决方案有:

  1. 创建,删除,合并(merge)新的分支.
--创建新分支
git branch branchName
--切换分支
git checkout  branchName
--分支合并
git merge branchName
--删除分支
git branch -d branchName
  1. 提供stash功能可以保存工作区中未提交时的内容.方便未来的某个时刻恢复工作区.

本地库和github交互:

--创建与远程分支关联的本地分支
git checkout -b branch-name origin/branch-name
--建立本地分支和远程分支的关联
git branch --set-upstream branch-name origin/branch-name;
--推送本地修改
git push origin branch-name
--同步远程修改
git pull
--clone远程分支
git clone git_address

以上的内容算是我使用git的一个知识框架.有很多的细节没有说明,但是只要有了这个框架,到时候填充细节的话就很容易了.

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,332评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,508评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,812评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,607评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,728评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,919评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,071评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,802评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,256评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,576评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,712评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,389评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,032评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,798评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,026评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,473评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,606评论 2 350

推荐阅读更多精彩内容