首先介绍一个git 里工作流的概念:

  你的本地仓库由 git 维护的三棵“树”组成。第一个是你的 工作目录,它持有实际文件;第二个是 缓存区(Index),它像个缓存区域,临时保存你的改动;最后是 HEAD,指向你最近一次提交后的结果。

1、git init命令用于初始化当前所在目录的这个项目。

2、git clone /path/to/repository 执行命令以创建一个本地仓库的克隆版本

3、git add <filename>  或 git add *  你可以计划改动(把它们添加到缓存区)

给我目前的这个项目制作一个快照snapshot(快照只是登记留名,快照不等于记录在案,git管快照叫做索引index)

4、git commit -m "代码提交信息"  : 用于将快照里登记的内容永久写入git仓库中,也就是开发者已经想好了要提交自己的开发成果了。(本地仓库)

  现在,你的改动已经提交到了 HEAD,但是还没到你的远端仓库。

6、推送改动

git push origin master

  你的改动现在已经在本地仓库的 HEAD 中了。执行如下命令以将这些改动提交到远端仓库,可以把 master 换成你想要推送的任何分支。

7、git remote add origin <server>

  果你还没有克隆现有仓库,并欲将你的仓库连接到某个远程服务器,你可以使用如下命令添加。如此你就能够将你的改动推送到所添加的服务器上去了。

分支

分支是用来将特性开发绝缘开来的。在你创建仓库的时候,master 是“默认的”。在其他分支上进行开发,完成后再将它们合并到主分支上。

1、git checkout -b feature_x 创建一个叫做“feature_x”的分支,并切换过去

2、git checkout master 切换回主分支

3、git branch -d feature_x 再把新建的分支删掉

4、git push origin <branch> 除非你将分支推送到远端仓库,不然该分支就是 不为他人所见的

5、运行 git fetch,可以将远程分支信息获取到本地。

更新与合并

1、要更新你的本地仓库至最新改动,执行:
git pull
以在你的工作目录中 获取(fetch) 并 合并(merge) 远端的改动。
2、要合并其他分支到你的当前分支(例如 master),执行:
git merge <branch>
两种情况下,git 都会尝试去自动合并改动。不幸的是,自动合并并非次次都能成功,并可能导致 冲突(conflicts)。 这时候就需要你修改这些文件来人肉合并这些 冲突(conflicts) 了。改完之后,你需要执行如下命令以将它们标记为合并成功:
git add <filename>
在合并改动之前,也可以使用如下命令查看:
git diff <source_branch> <target_branch>


git 命令补充:

git branch   -a (to show all the branches git knows about)

git branch -r (to show remote branches git knows about)

git fetch:相当于是从远程获取最新版本到本地,不会自动merge

git pull:相当于是从远程获取最新版本并merge到本地

完整路径:

git pull <远程主机名> <远程分支名>:<本地分支名

推送远程分支: git push origin local_branch:remote_branch

 

最新文章

  1. Deferred在jQuery和Angular中的使用与简单实现
  2. Python查找当前路径和子路径下指定后缀名的文件
  3. 各种UIButton
  4. connect VisualVM to Tomcat
  5. 关于Android中RemoveView的错误理解
  6. 水题 Codeforces Round #302 (Div. 2) A Set of Strings
  7. 微软职位内部推荐-Sr Development Lead-OSG-IPX
  8. mongodb安装指南
  9. Webfrom基础知识
  10. C#调用AForge实现摄像头录像
  11. Java Web应用集成OSGI
  12. freemarker自定义标签报错(二)
  13. Retrofit 2.0 超能实践(一),okHttp完美支持Https传输
  14. html 类似雷达扫描效果 及 闪屏效果
  15. ionic3 表单输入元素input的三种事件
  16. 测试创建表变量对IO的影响
  17. HTML DOM学习
  18. java开发之发牌小程序
  19. Excel 返回第2大的值
  20. Jquery js框架使用

热门文章

  1. VI快捷键速记
  2. 使用 Itext 生成PDF字节数组(文件流不落地)
  3. PMML辅助机器学习算法上线
  4. javascript之Location对象
  5. shaderToy学习篇
  6. three中的着色器示例
  7. Python列表排序
  8. Qt QLabel添加cliked事件
  9. Windows-T
  10. 03-初识JavaScript