git指令

把当前文件夹变成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 的简写,取首字母),显示对应的克隆地址。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值