在工作之余,做一些备忘是很重要的,之前在新浪博客真的是坑爹,吭哧吭哧几个小时的东西一不小心就全军覆没...2017在简书重新开始啦...
git可以说是每一个程序员最基本的代码管理工具,之前用SVN的都能深刻的感受到git的强大之处,在第三方工具横行的时代,有时候适当的使用一些命令会是代码管理更加便捷。(注:git的第三方工具最常见的就是sourceTree,之前用的时候感觉太过啰嗦,不过简洁,后来改用gitX,一直沿用到现在,文章末尾附百度云地址,各位需要可以自行下载)。
说到git,大家通常会和SVN做对比,首先一个截然不懂的地方就是,git有一个神器一般存在的暂存区。对于git,除了工作区(也就是你需要编辑的那个文件的区域),版本库中有一个神器的暂存区,Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD。从我个人看来,暂存区可以统一工作区多次修改统一提交,从很大程度上缓解对于版本库分支的复杂操作,增加容错性。
一、本地管理
1. 提交操作
(1). 配置全局用户名和邮箱
配置用户名 : git config --global user.name "ys"
配置邮箱 : git config --global user.email "ys@163.com"
获取全局配置信息 : git config --list
(2). 创建仓库
cd到你想要创建仓库的地址,运行 git init ,你会发现根目录下多了一个.git的文件夹,那么你的本地仓库就已经建好了
(3). 忽略文件
有时候有些文件我们不想每次提交,那么我们可以配置.gitignore,并把它放到根目录,忽略该文件的效果。eg:在里面添加 .DS_Store,则不会对该文件的修改加入到工作区中。有些已经跑过的项目,你会发现你在.gitignore加入 xcuserdata/ 后,UserInterfaceState.xcuserstate这个文件还是频繁更新,扰人至极,去掉这个文件的具体步骤如下:
到目录下把这个文件直接干掉,然后commit这次修改,重启Xcode就好了。
或者使用命令行:
git rm --cached 该文件路径
git commit -m "Removed stupid file"
(4). 查看仓库的当前状态
git status 查看当前文件状态
git diff 查看当前改动
git diff HEAD -- filename 查看该文件工作区与当前版本库的差别
(5). 查看之前的所有log
git log 查看详细改动
git log --pretty=oneline 简单方式查看版本改动
(6). 从工作区添加到暂存区
git add filename.txt 添加单个文件
git add *.txt 添加所有txt文件
git add . 添加所有文件
(7). 丢弃工作区中的修改
git checkout -- filename 丢弃对应文件的修改
git checkout head . 丢弃所有工作区的修改
(8). 将暂存的修改还原到工作区
git reset head 或者 git reset head filename
(9). 将暂存区的改动上传到仓库
git commit -m "commitSomething"
(10). 版本回归
首先,Git必须知道当前版本是哪个版本,在Git中,用HEAD表示当前版本,也就是最新的提交74399b158f9c557486c0f0074483e78f1184bb7c(注意我的提交ID和你的肯定不一样),上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100。
在这里,介绍一下 --hard --soft --mix(默认)
git reset --mixed:此为默认方式,不带任何参数的git reset,即时这种方式,它回退到某个版本,只保留源码,回退commit和index信息
git reset --soft:回退到某个版本,只回退了commit的信息,不会恢复到index file一级。如果还要提交,直接commit即可
Git reset --hard:彻底回退到某个版本,本地的源码也会变为上一个版本的内容
git reset --hard HEAD^ 回滚到上一个版本
注:我来个擦,突然发现回滚错了,天雷滚滚啊,怎么回去呢?在没关闭命令行的前提下,找到上次git log的日志,找到对应的版本号,输入git reset --hard 74399b158f9c557486c0f0074483e78f1184bb7c 你会发现,我的天,最后一条数据又回来了。哎呀,如果你说我都已经关了命令行了,别担心,你需要另外一个查看所有执行过的命令的神奇的 git reflog,你会神奇的发现所有的版本号都能看得到,于是你学会了上面的方式,成功回到人生巅峰。
2. 分支管理
(1). 创建分支
git checkout -b branchName (相当与: git branch branchName git checkout branchName两句命令)
git branch branchName b281e9cd7048a3ad70b5159ba47d4205eb476608 在指定节点创建分支
(2). 查看当前所有分支以及状态
git branch
(3). 合并分支
git merge branchName 用于合并指定分支到当前分支
(4). 删除分支
git branch -d branchName 删除指定分支
二、远程管理
首先登陆github创建一个远程仓库,获取到远程仓库的地址。(https://git.oschina.net/yang_shuai/gitTest.git)
(2). 克隆远程仓库
git clone https://git.oschina.net/yang_shuai/gitTest.git
(2). 查看本地远程仓库状态
git remote -v
(3). 链接远程仓库
git remote add origin https://git.oschina.net/yang_shuai/gitTest.git
(4). 清除远程仓库
git remote rm origin
(5). 获取远程库数据单不合并
git fetch origin
(6). 将本地分支推送到远程分支并合并
git push origin master:master master为分支名,前面的master为本地分支名,后面的master为远程分支名
(7). 获取并合并远程分支的两种方法
第一种: 使用git fetch 获取到当前最新的远程分支,然后使用git merge origin/master 进行合并。
第二种:直接使用 git pull origin master:master 获取并直接合并到对应分支。
针对两种获取合并方式,个人更推崇第一种,首先可以知道队友都改了些什么,另外可以准确的进行一对多的合并。
三、冲突解决
对于部分新手来说,解决冲突可以说是头疼的问题。目前有两种解决冲突的方式。
第一种:修改当前文件,也就是说在你编辑的文件中直接修改然后git add . ,git commit -m “mergeok”,手动保留你想要的修改。
第二种:自动解决冲突的工具,不过我还是不叫喜欢第一种,可控性强。
四、标签操作
git tag v1.0.0 (后面可加版本号在固定节点打上tag)
git tag 查看所有标签。
git tag -d v1.0.0 删除名称为v1.0.0的本地标签
git push origin :refs/tags/v1.0.0 删除名称为v1.0.0的远程仓库标签
GitX链接: https://pan.baidu.com/s/1pKZayDX 密码: txfj