git命令行使用指南

文章基于Mac版本的git操作.


关于 git.

  • 之前一直使用SVN, 开发个人项目时会使用GitHub Desktop, 笔者基于这一年里的git使用体会为有需要的同学们提供一些建议.
  • 对笔者而言, SVN更像是一个文件共享工具, 整个团队, 包括产品原型, UI切图和代码等等的共享工具. git更适合于单纯代码方面的管理, 包括个人的代码开发管理和几个人之间的团队协作.
  • git工具的使用很简单, 因为平常开发用得上的语法很少, 不过对于完全不了解的同学, 初次使用还是会觉得很陌生.

  • 首先git工具是用来做代码管理和协作开发的. 你可以把你的开发代码放到远程的GitHub仓库里(GitHub的私有仓库是需要付费的, 相对的公开仓库则免费, 如果你不介意把代码共享给大家). 每次到了一定的开发阶段就把自己的新代码提交到远端的仓库(比如做一天的开发任务之后提交, 又比如做一段有影响的代码之前提交, 这个就看个人的判断了). 这个功能点上可以理解成云储存功能.
  • git可以建立许多的分支, 每个分支下开发不同的功能, 或者是不同的人开发不同的分支. 不同的分支之间可以灵活切换, 合并. 分支也可以打上tag(标签)或者回滚, 总之我目前需要的功能他都有了. 这个功能点上其实和SVN是类似的.

关于日常 git 使用.

  • 使用git前需要在本地初始化git, 即git init. 然后需要设置与GitHub仓库的连接, 有HTTPS和SSL两种方式, 这方面请参考其他文章.
  • 1 假设已经存着远端仓库,打开终端terminal使用clone命令拉取远端仓库. 输入下方命令, 按照提示输入密码, 选择文件夹等. HTTPS 和 SSH 地址在GitHub 项目里面的绿色 Clone or download 按钮.
    git clone 项目地址(可以使用 HTTPS 或者 SSH 连接方式)
  • 2 接下来是主要讲的日常操作. 当你完成了一个功能或者一天的工作需要提交的时候. 打开 terminal, 进入项目文件夹并输入下面的命令.
    git add . //把所有修改的文件加入追踪库,当然你也可以单独选择部分文件
    git commit -m "注释" //提交到本地并注释
    git push origin issue1 //提交到远端, issue1 是远端分支名
    这三句可能是日常中用到的最多的语句, 添加 - 提交.
  • 3 如果你在不同的分支开发, 或者合并其他的分支时,就需要切换分支. 例如从 issue1分支切换到 issue2 分支.
    git checkout issue2 //切换到 issue2 分支
  • 4 如果多人开发, 需要合并他人的分支的时候(比如我本地的 issue2 需要合并远端的 issue3 ). 我的做法是先新建一个和远端需要合并的分支名字相同的分支(这个新建的分支是以本地的 issue2 为基础新建的, 所以合并前是和 issue2 一模一样的, 相当于复制了 issue2), 然后拉取远端分支和新建的分支合并, 解决完冲突之后再合并到本地分支当中.
    git branch -a //查看所以的分支, 包括本地分支和远端分支
    git checkout branch -b issue3 //以当前分支为基础新建名为 issue3 的分支并切换到 issue3, 这里是以 issue2 为基础新建 issue3
    git pull origin issue3 //拉取远端的 issue3 分支和本地的 issue3 分支进行合并, 这时可能会提示有冲突, 有冲突时需要解决冲突
    git add . //解决完 issue3 的冲突之后再提交到本地
    git commit -m "注释" //需要先 commit 之后才可以切换分支
    git checkout issue2 //切换到 issue2 分支
    git merge issue3 // 把解决完冲突的 issue3 分支合并到当前分支 issue2
    这时候的 issue2 就已经是合并完线上的最新的代码了, 接下来在按照正常的程序 push 上去就行了. 合并时也可以先 fetch 再 merge , 就是先把远端的拉下来不合并, 再通过 merge 命令进行合并. 上边的 pull 其实是 fetch 和 merge 的集合, 拉取远端并直接合并.

关于协同开发.
协同开发最难的是代码库的管理和代码的合并. 我通常是这么做的:

  • master 分支, master 分支是主分支, 每个上线版本都会合并到 master 分支上, 并打上 tag. master 分支仅由负责人进行管理.
  • develop 分支, 由 master 分支切出来的 develop 分支是开发的主分支, 每个开发人员完成自己的任务之后都会拉取 develop 分支进行合并, 解决冲突之后再提交到 develop 分支上.
  • 个人分支, 比如我叫 ken, 我就从 develop 分支上切出一个名为 ken 的分支作为我个人的主分支.
  • issue分支, 用来管理单独的功能代码, 一般采用 issueX 的命名, issue 和 GitHub 库的 issue 对应. 比如我需要 code 网络层的代码, 我就在 GitHub 仓库建立一个 issue4, 然后本地以 ken 分支为基础建立一个 issue4 分支.

我的习惯是会频繁的更新个人分支, 在 issue 分支的小阶段完成后或者大改之前会把 issue 分支合并到 ken 分支. 等 issue 稳定之后会合并到 ken 分支,再合并到 develop 分支. 以此保证每个功能, 每个开发人员代码的独立, 以及 develop 分支的稳定.

还有一点就是每个人尽量只改动自己的部分, 需要修改其他人的部分之前如果有可能最好先沟通, 特别是 xib 以及 storyboard. 这样可以减少90%以上的冲突, 特别是难以用冲突工具解决的冲突.

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

推荐阅读更多精彩内容

  • 多种多样的工作流使得在项目中实施Git时变得难以选择。这份教程提供了一个出发点,调查企业团队最常见的Git工作流。...
    JSErik阅读 4,353评论 2 8
  • 银龙 2011.10.21 是非成败皆成空, 万悲俱来又何从? 我持青云无敌剑, 直捣黄龙上九重! —end—
    醉仙王子阅读 89评论 0 0
  • 曾经以为,二十几岁之前的日子是那样漫长,长大成人似乎是一件遥不可及的事情。一路走来才明白,人生中经历过无数的瞬间里...
    西川紫阅读 935评论 2 8
  • 人都想把自己保护的很好,怕被欺骗,怕受伤害,怕吃大亏,所以人小心翼翼,表里不一,社交上裹了一层壳,说话开始言不由衷...
    两朵告别我阅读 283评论 0 0