Git是一套版本管理系统。看到“Git版本管理”,一大部分盆友已经转身想走,在你握着门把手准备开门走人时,请最后听我说完最后一句:人人都需要版本管理,git可以帮你少交停电/蓝屏/死机税,提高产出效率,不来一发吗? 试过半夜写汇报ppt吗?'汇报ppt'→'汇报ppt1'→'汇报ppt11'→'汇报ppt2015-03-17'→'汇报ppt2015-03-17新'→'汇报ppt2015-03-17新1'……无休止的命名斗争,这就是自然而然的版本管理,只不过,没有好的工具,所以显得一团mess。 无论学生党还是设计师(改20个版本后终于顺利用回第1版),无论公众号运营还是音乐人,都持续产出着自己的“半成品/作品”。99.99%的作品都不可能一气呵成,比如这篇笔记的第一个commit版本,简直惨不忍睹。如果有版本管理意识,以及高效、方便的工具,生活也许可以简单许多,更不要说天有不测风云的停电忘保存、脑残删备份等等好事等着我们。 来吧,fork有用有趣的东西,git你应该在意的东西,日拱一卒,打造我们的作品。 二、Git主要概念Git实现在本地和远端进行版本管理。 1.工作空间四个空间概念:工作目录(workspace),暂存区(index),本地仓库(local repository),远程仓库(remote repository) 想象一下,我们开一个包子店(图片做的不是同一款包子,见谅)~
配合下面这张图,我们对Git就有一个基本概念了。 Git系统的实质更像是一棵大树,树干(就是Head啦)是最后一次提交的成果。在树干上,你可以开无数的分支(就是branch啦)胡弄,弄乱了也不怕,大不了剪掉再开一个,树干不受任何影响。折腾ok的分支,最后可以merge到默认branch也就是master上。 用技术性语言描述,分支用来将特性开发绝缘开来。在创建仓库的时候,master 是“默认的”分支。在其他分支上进行开发,完成后再将它们合并到主分支上。 那origin又是什么?origin是远程默认的仓库。clone完成之后,Git会自动将远程仓库命名为origin。 那Head和master又是什么关系?Head其实只是个指针,指向当前最近commit的branch。而master是本地默认的branch,所以Head经常都是指向master。另外Head是官方定义的,而master和origin都是大家常用的命名,并不一定要叫master和origin。[2] 3.工作流:add & commit & push
Git的好处之一是,包子包好后,还可以回退…… 捷径: 1.工作目录 2.本地仓库 3.远程仓库 四、常用命令最常用: git command --help 需要进入目标目录进行操作
2.查询
Staging Area:commit前把文件们收集到一起,以便打包commit。 3.add/添加
4.commit/提交 'commit' 可以理解为一次快照,帮助我们把所有改动以timeline的方式组织起来。
5.push/推送 将文件推送到远程仓库中:git push -u origin master。远程仓库默认叫origin 。-u 告诉Git记住参数,下次可以直接使用push。 6.pull/拉取 更新本地仓库至最新改动:git pull origin master 7.checkout/切换 checkout命令用于从历史提交(或者暂存区域)中拷贝文件到工作目录,也可用于切换分支
8.diff/比对 git diff 9.reset/撤销
10.merge 合并其他分支到当前分支:git merge 11.remove & clean
Ref
HackYourself 关注普通人的心智升级,用知识的力量、用微小但持续有效的行动,每天做自我迭代升级。 |
|
来自: taotao_2016 > 《it》