- 出现没有被trace的文件 使用 git clean -fx -d
- 用clone的时候只会创建master分支
- git diff head Hello.txt 经常有这种情形,从远程pull了一个分支,我们想看看这次pull和我们本地文件有哪些改动。那么就可以这样操作,在pull之前使用commit,然后使用 git diff head fileName来查看差异
3 分支
3.1 拉取分支到本地并建立关联关系
- 在多人协作的时候,经常有这样的问题,想把远程分支弄到本地。比如远程分支(即为b2)是别人的分支,想拉到本地看看。直接本地a分支,创建本地b2分支,在pull远程b2到本地b2会有两个问题,一个是基于a创建的b2,在拉了远程b2之后,会有a分支内容;其次这种方式并没有建立本地b2和远程b2之间的联系。
正确的操作步骤应该是
法一:
git checkout -b 本地分支名x origin/远程分支名x
使用该方式会在本地新建分支x,并自动切换到该本地分支x。
采用此种方法建立的本地分支会和远程分支建立映射关系。
法二
git fetch origin 远程分支名x:本地分支名x
使用该方式会在本地新建分支x,但是不会自动切换到该本地分支x,需要手动checkout。
采用此种方法建立的本地分支不会和远程分支建立映射关系。
Note:包括fetch以及
git branch -vv 查看本地所有分支和远程分支的关系
3.2 分支合并
当前在分支 b1,如果想合并b2。则可以直接在当前分支上 git merge b2
也可以 使用 git merge b1 b2,将b2合并到b1
**记录git使用过程的常见错误 权当笔记
4 常见问题
4.1 gitinore失效问题
代码中igore配置如下图所示,但是最后push代码的时候发现,以上所有的代码都被上传到了origin,即ignore配置没有生效。
解决方法:
首先确保远程仓库有.gitignore文件,没有首先push该文件,
然后在本地执行
git rm --cached -r .idea
其他的target文件亦是如此。