git GUI管理工具 sourcetree使用
sourectree安装包下载 SourceTree安装包路径html
sourcetree安装后配置 Sourcetree SSH配置git
sourcetree忽略文件设置 http://www.javashuo.com/article/p-gsbwaxnc-ka.html缓存
sourcetree使用参考 http://www.javashuo.com/article/p-hmqrknfg-km.html工具
git与sourcetree名词映射关系
- 克隆(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命令行
git命令-代码提交步骤
- cd命令进入项目目录而后以下
- 修改完代码后,git status查看本身的文件修改列表;
- git diff <文件名> 查看本身的文件修改记录;
- git add <文件名> 添加须要提交的文件列表;
- git commit -m "提交说明"
- git pull,更新一下当前最新的代码;
- 解决冲突(若有冲突)
- git push 提交代码
git commit 模板
故事id #comment
: 提交描述
测试
type用于说明 commit 的类别,可使用以下类别:fetch
- add:新功能(feature)
- delete:删除
- fix:修复功能(不是bug状况的修改)
- bug:修复bug
- doc:文档(documentation)
- style: 格式(不影响代码运行的变更,好比代码缩进)
- refactor:重构(即不是新增功能,也不是修改bug的代码变更)
- test:增长测试
- chore:构建过程或辅助工具的变更
- other:其余非正常操做,好比修改.gitignore文件
- (注:没有故事id使用项目ID)
git 代码冲突
<<<<<<<<<<<<<<< HEAD
区间1---你新修改事后的代码
==================
区间2---你修改前的代码
>>>>>>> 9acad6f05c829cf34347e19286ff050708d70809
(通常手动解决冲突,将区间2中代码删掉(注意本身检查),将自动生成的 <<<<< ====== >>>>>>也删掉)
git Merge .orig
.orig是merge时生成的备份文件,下面命令配置能够实现不生成这些文件:
git config --global mergetool.keepBackup falseui