git 基本操作

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”,你的搁置的代码就回来了。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值