git config -list 查询配置信息
(1). 返回上一级目录:cd .. (cd 与 .. 之间有一空格)。
(2). 进入某一目录:cd git (进入 git 目录)。
(3). 显示当前路径:pwd。
git push -u origin master (第一次要用-u 以后不需要)
//git pull --rebase origin master (最好不要用因为变基)
先:
git pull origin master
然后再进行:
git push origin master
删除:git remote rm origin
修改命令: git remote origin set-url [url]
2.先删后加 git remote add origin [url]
打标签
git tag -a v1.01 -m "Relase version 1.01"
注解:git tag 是打标签的命令,-a 是添加标签,其后要跟新标签号,-m 及后面的字符串是对该标签的注释。
提交标签到远程仓库
git push origin -tags
注解:就像git push origin master 把本地修改提交到远程仓库一样,-tags可以把本地的打的标签全部提交到远程仓库。
删除标签
git tag -d v1.01
注解:-d 表示删除,后面跟要删除的tag名字
删除远程标签
git push origin :refs/tags/v1.01
注解:就像git push origin :branch_1 可以删除远程仓库的分支branch_1一样, 冒号前为空表示删除远程仓库的tag。
查看标签
git tag
或者
git tag -l
回滚单个文件
直接用 git checkout 即可。理解起来稍微有点奇怪就是了。
$ git checkout ${commit} /path/to/file
git checkout xxxxx(文件名)
添加多远程
git remote add <name> <url>
其中,name 表示你要给这个远程库起的名字,url 表示这个库的地址
删除多远程
git remote remove comorigin
#查看所有的分支,包括远程的
git branch -a
git checkout -b 分支名 //创建并切换到分枝
#删除本地的某个分支
git branch -D hongchangfirst
#删除远程的分支 (伪删除——只删除了本地)
git branch -r -d origin/hongchangfirst
#注意这个只是删除本地的索引,而不是真正删除远程分支的内容,要想真正删除远程分支上的内容,可以这样:
git push origin :hongchangfirst
注意,冒号前面的空格不能少,相当于把一个空分支push到server上,等于删除该分支。
git merge 和 git rebase 小结 区别
git commit -m 与 git commit -am 的区别
当修改已经通过git add <change file>将其添加到stage,可以通过git commit -m "<message>"为这所有已经进入stage的改变添加一个commit信息。什么是在stage中?看下面
如果你的文件之前已经提交过,但这次的改动还没有进stage,如下:
可以直接使用git commit -am "<message>",将所有修改,但未进stage的改动加入stage,并记录commit信息。(某种程度上相当于git add和git commit -m的组合技,前提是被改动文件已经是tracked)
git commit -am "str" #等同于 git commit -a -m "str"
通常我们提交git的时候都是
git add .
git commit -m "some str"
git push
这三大步,而实际上,你只需要两条命令就够了,除非有新的文件要被添加进去。
git commit -am "some str" git push
自动把当前所有修改和删除文件放到栈上,但你没有添加过的不会受影响git。
git stash 与 shelve
使用git stash
有时候写了一半的JAVA代码,都还不能编译通过的,就被叫去改另一个分支的bug了。
在new分支上的时候在命令行输入:
git stash
或者
git stash save “修改的信息"
这样以后你的代码就回到自己上一个commit了,直接git stash的话git stash的栈会直接给你一个hash值作为版本的说明,如果用git stash save “修改的信息”,git stash的栈会把你填写的“修改的信息”作为版本的说明。
接下来你回到old分支修改代码完成,你又再回到new分支,输入:
git stash pop
或者
git stash list
git stash apply stash@{0}
就可以回到保存的版本了。git stash pop的作用是将git stash栈中最后一个版本取出来,git stash apply stash@{0}的作用是可以指定栈中的一个版本,通过git stash list可以看到所有的版本信息:
stash@{0}: On order-master-bugfix: 22222
stash@{1}: On order-master-bugfix: 22222
然后你可以选择一个你需要的版本执行:
git stash apply stash@{0}
这时候你搁置的代码就回来了。
用IDE工具的shelve的功能
有一些IDE工具提供了shelve的功能,shelve的意思是“将…搁在一边”,即把还没写完的代码先搁在一边。我开发都是使用jetbrains公司的IDEA和PhpStorm,它们就提供了shelve的功能,方法:
首先在IDE的底部找到“Changes”,点开会有local的选项卡,选中你要搁置的代码,点击右键,选择“Shelve Changes”,在提交的输入框中输入你的注释,以便回来的时候识别你需要的版本,点击“Shelve Changes”键即可。这时选项卡上会多一个“Shelf”的选项卡,里面就有你搁置的代码。
这时候你可以去old分支修改代码,改完了之后回到new分支,到“Shelf”选项卡下选择你要恢复的代码或者版本,点击右键选择“Unshelve Changes”,你的搁置的代码就回来了。