sourceTree初识
GUI for git|SourceTree|入门基础
目录
- SourceTree简介
- SourceTree基本使用
- SourceTree&Git部分名词解释
- 相关连接推荐
一、SourceTree简介
SourceTree 是 Windows 和Mac OS X 下免费的 Git 和 Hg 客户端,拥有可视化界面,容易上手操作。同时它也是Mercurial和Subversion版本控制系统工具。支持创建、提交、clone、push、 pull 和merge等操作。
二、SourceTree基本使用
(以下以SourceTree For Mac V2.0.5.2中文版为例,托管平台以Github为例)
- 基本安装 
 1.1.
 不建议在appstore直接搜索下载SourceTree,因为appstore里的版本已经十分老旧(好像是2012年更新的)。建议前往官网下载安
 装最新版,我这里也提供一个SourceTree for Mac V2.0.5.2的百度云的方便链接。 传送门→SourceTreeDownload
 1.2. 拖动安装,Launchpad中打开,continue,输入github账号按下一步完成即可。没有Github账号的朋友,也可以跳过本步骤完成安装
- 注册GitHub(已有Github账号的朋友请跳过本步骤) 
 2.1. 打开Github官网 传送门→Github
 2.2. 填写必要的信息,点击sigh up for github Github Register 1 Github Register 1- 2.3. 默认选中免费账号,点击绿色的Finish sign up即可  Github Register 2 Github Register 2
- 实践入门-创建仓库 clone&pull 
 3.1. 创建仓库
 用我们刚才创建的账号登陆github,在欢迎页点击“+ New repository“创建我们的仓库 Create Repository 1 Create Repository 1- 或点击右上角的“+”,然后再New repository亦可  Create Repository 2 Create Repository 2- 3.2. 按照个人需要填写仓库名、仓库描述等,建议勾选“Initialize this repository with a README”(注意此处免费账户只能选择建立public(开源)仓库),填写完成后点击Create repository  Create Repository 3 Create Repository 3- 3.3. 至此,我们的仓库已经创建成功。创建成功后,我们在页面的右下角找到链接,点击复制  Copy Link Copy Link- 3.4. 打开我们的SourceTree,点击:“+新仓库”,选择:“从URL克隆”  Clone 1 Clone 1- 3.5. 粘贴我们的仓库链接至源URL,SourceTree会自动帮我们生成目标路径(本地仓库路径)以及名称,点击克隆  Clone 2 Clone 2- 3.6. 等待数秒后,SourceTree会为我们自动打开我们刚才克隆的仓库,选择master选项,这里我们可以看到我们仓库里的所有文件  MainPage MainPage- 3.7. 
 接下来我们想要上传一个项目至我们的远程Github仓库内。我们点击右上角“在Finder”中显示。然后SourceTree会帮我们打开我们的本地
 仓库,我们将需要上传的项目复制到本地的Finder文件夹内,然后关闭文件夹,回到主页面。我们会发现工作副本出现了更改提示 Change Notification Change Notification- 3.8. 我们点击工作副本,然后我们发现我们刚才上传的文件都在未暂存文件当中,此时,我们勾选“未暂存文件”  工作副本 1 工作副本 1- 3.9. 发现我们的文件变成了已暂存文件。此时,我们可以输入更新信息,然后,点击提交按钮  工作副本 2 工作副本 2- 3.10. 
 我们切换回master分支,会发现master分支以及推送(Push)按钮,都出现了更改提示。这表示SourceTree已经将我们刚才添加的文件
 成功提交到本地仓库,而本地仓库的内容则比远程仓库超前了一个版本。我们这个时候点击推送(Push)即可将本地仓库的内容同步至远程仓库。 Branch Master Branch Master- 3.11. 点击推送(push),等待片刻即可,我们重新登录github网站,会发现我们刚才本地仓库的文件已经成功推送到远程仓库  Push Push
- 实践入门-参与开源 Fork&pull request 
 (以下以 [https://github.com/octocat/Spoon-Knife] 举例)
 4.1. 首先打开上述页面,然后点击右上角“fork”按钮。fork意味着将他人的仓库复制到我们账号中。如果我们想要参与开源项目,首先要fork下别人的项目,然后在我们复制过来的仓库中,对别人的代码做修改。 fork fork- 4.2. fork完之后,我们用上文提到的方法,将自己账号中的[Spoon-Knife]仓库克隆(clone)到本机SourceTree中,并在稍作更改后,推送(push)到自己账号的远程仓库 
 4.2.1 在SourceTree中建立新仓库,并复制URL clone Spoon-Knife clone Spoon-Knife- 4.2.2 在本地仓库中稍作更改(如图我新建了一个Test)  Example Example- 4.2.3 通过上文方法推送(Push),登陆Github,进入Spoon-Knife仓库,发现test已经上传到我们账号的远程仓库Spoon-Knife当中  Success Success- 4.3. 上传完后,我们点击Github branch旁的绿色按钮  Pull Request 1 Pull Request 1- 4.4. 之后我们会进入一个Compare页面,这个页面用于比较作者仓库与我们仓库的文件的不同。Base fork:指的是作者仓库目录地址;Head fork:指的是我们账号中fork后所产生的仓库地址。我们点击Create pull request即可  Compare Compare- 4.5. 然后我们会进入一个Pull 
 Request界面,在这里,我们可以输入自己更改的原因/更改的内容。这里写的文字会显示给源代码作者,如果作者接受了我们的推送请求(pull
 request)后,我们的代码将会上传到源代码作者的仓库内,成功为开源做贡献。如果作者拒绝了我们的推送请求(pull
 request)后,我们的代码将不会上传到源代码作者的仓库内。 Pull Request 2 Pull Request 2- 4.6. 我们点击Create Pull Request即可,系统将自动跳转到等待回复的页面,这里会显示作者是否接受我们的代码更改。  Pull Request 3 Pull Request 3- 三、SourceTree&Git部分名词解释- 克隆(clone):从远程仓库URL加载创建一个与远程仓库一样的本地仓库
- 提交(commit):将暂存文件上传到本地仓库(我们在Finder中对本地仓库做修改后一般都得先提交一次,再推送)
- 检出(checkout):切换不同分支
- 添加(add):添加文件到暂存区
- 移除(remove):移除文件至暂存区
- 暂存(git stash):保存工作现场
- 重置(reset):回到最近添加(add)/提交(commit)状态
- 合并(merge):将多个同名文件合并为一个文件,该文件包含多个同名文件的所有内容,相同内容抵消
- 抓取(fetch):从远程仓库获取信息并同步至本地仓库
- 拉取(pull):从远程仓库获取信息并同步至本地仓库,并且自动执行合并(merge)操作,即 pull=fetch+merge
- 推送(push):将本地仓库同步至远程仓库,一般推送(push)前先拉取(pull)一次,确保一致
- 分支(branch):创建/修改/删除分枝
- 标签(tag):给项目增添标签
- 工作流(Git Flow):团队工作时,每个人创建属于自己的分枝(branch),确定无误后提交到master分枝
- 终端(terminal):可以输入git命令行
 
四、相关链接推荐
sourceTree初识的更多相关文章
- Android动画效果之初识Property Animation(属性动画)
		前言: 前面两篇介绍了Android的Tween Animation(补间动画) Android动画效果之Tween Animation(补间动画).Frame Animation(逐帧动画)Andr ... 
- 初识Hadoop
		第一部分: 初识Hadoop 一. 谁说大象不能跳舞 业务数据越来越多,用关系型数据库来存储和处理数据越来越感觉吃力,一个查询或者一个导出,要执行很长 ... 
- python学习笔记(基础四:模块初识、pyc和PyCodeObject是什么)
		一.模块初识(一) 模块,也叫库.库有标准库第三方库. 注意事项:文件名不能和导入的模块名相同 1. sys模块 import sys print(sys.path) #打印环境变量 print(sy ... 
- 初识IOS,Label控件的应用。
		初识IOS,Label控件的应用. // // ViewController.m // Gua.test // // Created by 郭美男 on 16/5/31. // Copyright © ... 
- UI篇(初识君面)
		我们的APP要想吸引用户,就要把UI(脸蛋)搞漂亮一点.毕竟好的外貌是增进人际关系的第一步,我们程序员看到一个APP时,第一眼就是看这个软件的功能,不去关心界面是否漂亮,看到好的程序会说"我 ... 
- Python导出Excel为Lua/Json/Xml实例教程(一):初识Python
		Python导出Excel为Lua/Json/Xml实例教程(一):初识Python 相关链接: Python导出Excel为Lua/Json/Xml实例教程(一):初识Python Python导出 ... 
- 关于如何使用sourcetree将本地项目提交到远端github总结?
		使用sourcetree将本地项目提交到github里,目前来说还是很流行的,我也是听说好玩,所以来琢磨了一下,从环境搭建到配置好,差不多用了一下午加一晚上的时间,有点虐心,好吧,废话不多说,介绍一下 ... 
- 初识SpringMvc
		初识SpringMvc springMvc简介:SpringMVC也叫Spring Web mvc,属于表现层的框架.Spring MVC是Spring框架的一部分,是在Spring3.0后发布的 s ... 
- 初识redis数据类型
		初识redis数据类型 1.String(字符串) string是redis最基本的类型,一个key对应一个value. string类型是二进制安全的.意思是redis的string可以包含任何数据 ... 
随机推荐
- 【c#】Form调用百度地图api攻略及常见问题
			首先,在Form中调用百度地图api,我们需要使用webbrowser控件,这个在前面的文章中已经讲过了,可以参照(http://blog.csdn.net/buptgshengod/article/ ... 
- RollPagerView的用法:
			RollPagerView的用法: /** * * @author smiling * @date 2016/10 */ Android Studio 导包: compile 'com.jude:ro ... 
- Lombok介绍及使用方法
			lombok简介 lombok是暑假来到公司实习的时候发现的一个非常好用的小工具,刚见到的时候就感觉非常惊艳,有一种相见恨晚的感觉,用了一段时间之后感觉的确挺不错,所以特此来推荐一下. lombok的 ... 
- C# ZXing.Net生成二维码、识别二维码、生成带Logo的二维码(二)
			1.使用ZXint.Net生成带logo的二维码 /// <summary> /// 生成带Logo的二维码 /// </summary> /// <param name ... 
- form表单提交
			1.form表单提交.html页面失败 <%--客户端form--%> <form id="form2" action="LoginOne.html&q ... 
- 粗俗易懂的SQL存储过程在.NET中的实例运用
			整理了一下存储过程在项目中的运用,防止遗忘,便记录于此!存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中.用户通过指定存储过程的名字并给出参数( ... 
- Jquery插件 easyUI属性汇总
			属性分为CSS片段和JS片段. CSS类定义:1.div easyui-window 生成一个window窗口样式. 属性如下: 1)mod ... 
- webApi项目中的问题
			1.场景:客户端调用API获取所有品牌列表,使用redis存储,第一次是获取全部,之后会增量获取,通过lasttime参数 出现的问题:redis连接超时,网络流量太大 原因:这个借口没做本地缓存,每 ... 
- 1109HTML学习
			<div><!--face里面用逗号隔开表示 字体优先选择.size是字体1到7 --><font color="red" face="微软 ... 
- cxf所用的lib
			cxf_lib 
