把当前文件夹变成Git可以管理的仓库:
git init
把文件filename添加到仓库:
git add filename
把整个文件夹添加到仓库:
git add dirname/
把暂存区的文件提交到仓库:
git commit -m "text"
显示git的日志:
# 显示所有日志和完整的版本号,每条日志只用一行表示
git log --pretty=oneline
# 显示最新的20条日志和简写的版本号,每条日志只用一行表示
git log --oneline -n 20
# 显示最新的20条日志、完整的版本号、作者、日期,每条日志用图表(多行)表示
git log --graph -n 20
回退到上一个版本:
git reset --hard HEAD^
回退到上上个版本:
git reset --hard HEAD~2
回退到指定版本:
git reset --hard 73f4
退回merge前?待考证,慎用,建议用上面那几个
git reset --merge
查看git命令历史:
git reflog
查看git状态:
git status
查看工作区和版本库里面最新版本的区别:
git diff HEAD -- filename
比较两个版本,列出有改动的地方:
git diff 8039266 802fc97
比较两个版本,列出有改动的文件名:
git diff --name-only 8039266e0a52a79418e0ee5b7f20a0361ba84059 802fc97bfd41fabf6e3549a6bf4d3b1644af6885
命令git checkout -- filename意思就是,把filename文件在工作区的修改全部撤销,这里有两种情况:
1.一种是filename自修改后还没有被放到暂存区,现在,撤销修改就回到和版本库一模一样的状态;
2.一种是filename已经添加到暂存区后,又作了修改,现在,撤销修改就回到添加到暂存区后的状态。
总之,就是让这个文件回到最近一次git commit或git add时的状态。
git checkout -- filename命令中的--很重要,没有--,就变成了“切换到另一个分支”的命令
git checkout -- filename
1.本地删除文件后,git上也要跟着删掉
git rm test.txt 或 git add test.txt
git commit -m "text"
2.本地删除文件后发现误删,想要恢复
git checkout -- test.txt
一 本地分支
创建本地分支,然后切换到dev分支
$ git checkout -b dev
git checkout命令加上-b参数表示创建并切换,相当于以下两条命令:
$ git branch dev
$ git checkout dev
然后,用git branch命令查看当前分支:
$ git branch
* dev
master
基于release-2.0分支新建分支release-2.1, 并切到新创建的分支上
$ git checkout -b release-2.1 release-2.0
添加文件 "Readme.txt", 提交到本地dev分支
$ git add Readme.txt
$ git commit -m "branch dev test"
dev分支的工作完成,切换回master分支:
$ git checkout master
把dev分支的工作内容合并到master分支上:
$ git merge dev
git merge命令用于合并指定分支到当前分支。合并后,再查看Readme.txt的内容,和dev分支的最新提交是完全一致的。
Fast-forward信息代表:“快进模式”,直接把master指向dev的当前提交,合并速度快。
并非每次代码合并都能实现Fast-forward。
合并完成后,删除dev分支:
$ git branch -d dev
删除后,查看branch,就只有master分支了:
$ git branch
* master
创建、合并和删除分支非常快,鼓励你使用分支来完成某个短期任务,合并后再删掉,比起直接在master上工作过程更安全。
参考链接:
git merge一个指定文件
$ git checkout dev hello.txt
把 dev 分支的 hello.txt 文件覆盖到当前的分支上
参考链接:
更新远程仓库代码到本地:
查看远程分支
使用如下命令可以查看远程仓库(我这里有一个origin仓库)
$ git remote -v
origin git@github.com:username``/Animations``.git (fetch)``origin git@github.com:username``/Animations``.git (push)`
从远程获取最新版本到本地
使用如下命令可以在本地新建一个temp分支,并将远程origin仓库的master分支代码下载到本地temp分支
$ git fetch origin master:temp
remote: Counting objects: 18, ``done``.``remote: Compressing objects: 100% (6``/6``), ``done``.``remote: Total 11 (delta 3), reused 0 (delta 0)``Unpacking objects: 100% (11``/11``), ``done``.``From github.com:username``/Animations`` ``* [new branch] master -> temp`` ``c07bdc7..40f902d master -> origin``/master`
比较本地仓库与下载的temp分支
使用如下命令来比较本地代码与刚刚从远程下载下来的代码的区别:
$ git diff temp
diff --git a/README.md b/README.md``deleted file mode ``100644``index 76699ed..``0000000``--- a/README.md``+++ /dev/``null``@@ -``1``,``6` `+``0``,``0` `@@``-Animations``-==========``-``。。。`
合并temp分支到本地的master分支
对比区别之后,如果觉得没有问题,可以使用如下命令进行代码合并:
$ git merge temp
Updating c07bdc7..40f902d``Fast-forward`` ``README.md | 6 ++++++`` ``src``/cn/exercise/animations/MainActivity``.java | 4 ++--`` ``2 files changed, 8 insertions(+), 2 deletions(-)`` ``create mode 100644 README.md`
删除temp分支
如果temp分支不想要保留,可以使用如下命令删除该分支:
$ git branch -d temp
Deleted branch temp (was 40f902d).`
如果该分支的代码之前没有merge到本地,那么删除该分支会报错,可以使用git branch -D temp强制删除该分支。
参考链接:
额外参考链接:
提交代码到远端:
$ git push <远程主机名> <本地分支名>:<远程分支名>
$ git push origin master
1.1 git push origin master
如果远程分支被省略,如上则表示将本地分支推送到与之存在追踪关系的远程分支(通常两者同名),如果该远程分支不存在,则会被新建
1.2 git push origin :refs/for/master
如果省略本地分支名,则表示删除指定的远程分支,因为这等同于推送一个空的本地分支到远程分支,等同于 git push origin --delete master
1.3 git push origin
如果当前分支与远程分支存在追踪关系,则本地分支和远程分支都可以省略,将当前分支推送到origin主机的对应分支
1.4 git push
如果当前分支只有一个远程分支,那么主机名都可以省略,形如 git push,可以使用git branch -r ,查看远程的分支名
1.git remote 不带参数,列出已经存在的远程分支
2.git remote -v | --verbose 列出详细信息,在每一个名字后面列出其远程url,此时, -v 选项(译注:此为 –verbose 的简写,取首字母),显示对应的克隆地址。