【Git使用】SourceTree+Git简单使用(Windows)(转)
导读:
本人过去Git的可视化工具用的是TortoiseGit,虽然Android Studio也能进行版本管理,但是用下来,感觉SoureTree这款工具是最舒服的(免费的),下面就给大家介绍下我的使用总结.
SourceTree简介
SourceTree 是 Windows 和Mac OS X 下免费的 Git 和Hg客户端,拥有可视化界面,容易上手操作.同时它也是Mercurial和Subversion版本控制系统工具.支持创建、提交、clone、push、pull和merge等操作.
同时SourceTree也支持与SVN同步(不建议这样弄)
准备工作
下载并安装相关工具:
Beyond Compare 4 官网下载 (可视化的,用于SourceTree解决版本冲突的插件)
嫌麻烦的朋友从这里下
配置SourceTree
- 配置插件(当然如果你用原生的不用理我)
- 配置用户名/邮箱
==注意:==
- 先安装Git再安装SourceTree(鼠标右键桌面,有Git相关的东西即为装好Git)
- 在SourceTree官网下载或者使用最新版都得先注册而注册的验证码是google提供的,需要***
- SourceTree安装到”Remote”跳过初始设置->SSH密钥取消(看情况)->Mercurial不用安装
使用步骤
一、 在代码托管平台新建仓库(这里以GitHub为例)
- 注册GitHub然后点击右上角+号新建repository
- 配置GitHUb上Repository相关参数
==小扩展:GitHub删除Repository==
二、 将GitHub仓库Link到我们的SourceTree
- 复制xxx.git链接
- 点击”克隆/新建”->配置下图:
- 将要传到GitHub的项目,复制到本地仓库路径(这里传一个moudle或传一个project,注意在GitHub的Readme.md上提醒别人导文件方式)
- 上图的Readme.md会显示如下:
三、 将项目提交到本地仓库
四、 将项目推送到GitHub仓库->刷新一下GitHub,可见已上传成功了
==小扩展:==
- 配置.gitignore忽略文件
- 如果想把某个文件也丢到.gitignore忽略文件
- 标签TAG使用:
给某个文件打上标签,方便下次修改代码快速定位
分支管理与使用
软件中的分支介绍(实际按公司项目为准)
创建分支的两个方法:
合并分支
==注意:==
- 首先要切换到被合并的分支上,再进行合并操作。
- 分支合并时,可以选择具体的某提交进行合并,同时主分支可以合并到子分支;子分支可以合并到主分支;子分支之间也可以进行合并。
推送分支到远程仓库
SourceTree&Git部分名词解释
克隆/新建(clone):从远程仓库URL加载创建一个与远程仓库一样的本地仓库
提交(commit):将暂存文件上传到本地仓库(我们在Finder中对本地仓库做修改后一般都得先提交一次,再推送)
推送(push):将本地仓库同步至远程仓库,一般推送(push)前先拉取(pull)一次,确保一致
拉取(pull):从远程仓库获取信息并同步至本地仓库,并且自动执行合并(merge)操作,即pull=fetch+merge
获取(fetch):从远程仓库获取信息并同步至本地仓库
分支(branch):创建/修改/删除分枝
合并(merge):将多个同名文件合并为一个文件,该文件包含多个同名文件的所有内容,相同内容抵消
贮藏(git stash):保存工作现场
丢弃(Discard):丢弃更改,恢复文件改动/重置所有改动,即将已暂存的文件丢回未暂存的文件
标签(tag):给项目增添标签
工作流(Git Flow):团队工作时,每个人创建属于自己的分枝(branch),确定无误后提交到master分支
终端(terminal):可以输入git命令行
每次拉取和推送的时候不用每次输入密码的命令行:git config credential.helper osxkeychain sourcetree
检出(checkout):切换不同分支
添加(add):添加文件到缓存区
移除(remove):移除文件至缓存区
重置(reset):回到最近添加(add)/提交(commit)状态
扩展:参与开源项目开发
找到一个想要参于的项目,点击Fork,Link xxx.git地址
写完我们的代码,如上上传仓库后,点击下图按键
进入Compare页面,比较我们与作者的文件->点击Create pull request->填写上传描述->等待作者自己合并项目即可
总结
这篇是SoureTree的简单使用,后续新增SoureTree解决版本冲突问题学习
更新来了-> SourceTree冲突解决
参考链接:https://blog.csdn.net/u012792686/article/details/63684248
【Git使用】SourceTree+Git简单使用(Windows)(转)的更多相关文章
- Git本地项目上传 & SourceTree & GitHub 简单使用
Git(分布式版本控制系统) Git是一款免费.开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目. Git是一个开源的分布式版本控制系统,用以有效.高速的处理从很小到非常大的项目版本管理 ...
- 手把手教你用git和SourceTree上传项目到github细解(转)
尊重原创:https://blog.csdn.net/qq_32365567/article/details/52859166 一.引言 我想大家现在都很熟悉github了,也能运用github上开源 ...
- Git凭证存储(简单易懂,一学就会,认真看)
今天给自己提了一个问题,当我们在github.com或者gitlab上面新建仓库,并克隆到本地,首次使用的时候,会被问及用户名密码,但是这两个信息存在哪里呢? 带着这个问题,我开始搜索,并在<P ...
- Git 基础学习篇(应用-windows篇)
此篇教程主要是讲应用,因为理论,,,额,我也说不出来.大家要深入学习还是看廖老师的教程吧. 可以把这篇当作一个简单应用的参考,因为当初看廖老师的也难看啊!!! 以下是资料: 廖雪峰-Git教程 [Gi ...
- Windows下搭建Git 服务器: BONOBO GIT SERVER + TortoiseGit
本文将介绍如何在Windows操作系统下搭建Git服务器和客户端.服务器端采用的是Bonobo Git Server,一款用ASP.NET MVC开发的Git源代码管理工具,界面简洁,基于Web方式配 ...
- git的安装和简单使用
目前windows版本的git有几种实现,但我们选择msysgit发行版,这是目前做得兼容性最好的. 下载地址: http://code.google.com/p/msysgit/downloads/ ...
- 小丁带你走进git世界一-git简单配置
小丁带你走进git世界一-git简单配置 1.github的简单配置 配置提交代码的信息,例如是谁提交的代码之类的. git config –global user.name BattleHeaer ...
- SourceTree&Git部分名词解释
SourceTree&Git部分名词解释 克隆(clone):从远程仓库URL加载创建一个与远程仓库一样的本地仓库 提交(commit):将暂存文件上传到本地仓库(我们在Finder中对本地仓 ...
- Eclipse Git和sourceTree用法
Eclipse Git和sourceTree用法 Eclipse Git: 提交代码到git: 1.team->Repository->pull 若没有冲突: 2.team->com ...
随机推荐
- spring-AOP框架(基于配置文件的方式配置AOP)
.xml: ref-指向,order-指定优先级
- Linux split命令参数及用法详解---linux分割文件命令
转载自:http://blog.csdn.net/xiaoshunzi111/article/details/52173994 功能说明:分割文件. Split:按指定的行数截断文件 格式: spli ...
- CPS(Cyber-Physical Systems)白皮书-摘选
<中国制造2025>提出,“基于信息物理系统的智能装备.智能工厂等智能制造正在引领制造方式变革”,要围绕控制系统.工业软件.工业网络.工业云服务和工业大数据平台等,加强信息物理系统的研发与 ...
- shell 查看去掉windons中的换行符
查看 cat -v 1.sh 替换 sed -i 's/\r//g' 1.sh
- 超细讲解Django打造大型企业官网
本文为知了课堂黄勇老师讲的<超细讲解Django打造大型企业官网>的笔记. 第一章 Django预热 1.创建virtualenv虚拟环境 2.URL组成部分详解 3.Django介绍 4 ...
- django 数据模型中 null=True 和 blank=True 有什么区别
null: If True, Django will store empty values as NULL in the database. Default is False. 如果为True,空值将 ...
- WebGL和ThreeJs学习6--射线法确定3D空间中所选物体
一.在 threejs 中如何确定下图3D空间中鼠标点击位置的 object 对象? 二.射线法确定步骤及代码 //Three.js提供一个射线类Raycaster来拾取场景里面的物体.更方便的使用鼠 ...
- webGL之three.js入门2
入门建议: webGL中文翻译教程,基于NeHe的openGL教程:http://www.hiwebgl.com/?p=42 . WebGL中文网 http://www.hewebgl.com/ ,里 ...
- C# 基于大整数类的RSA算法实现(公钥加密私钥解密,私钥加密公钥解密)
但是C#自带的RSA算法类RSACryptoServiceProvider只支持公钥加密私钥解密,即数字证书的使用. 所以参考了一些网上的资料写了一个RSA的算法实现.算法实现是基于网上提供的一个大整 ...
- 【springboot】之将properties配置转为bean
将springboot里面非application.yml 或者application.properties 里面的key-value转为JavaBean /** * @Describe: DataS ...