##git常用命令
- 查询分支:git branch
- 查询历史:git log
- 查询状态:git stuts
- 提交修改:git commit -am “information” 或者git add . && git commit -m “information”
- 切换到历史分支:git reset --hard ****
- 远程提交:git push origin HEAD:refs/for/dev_new_feature
Step1. 在本地仓库中, 回滚本地的提交记录
git fetch origin dev_new_feature
git reset --soft origin/dev_new_feature
Step2. 重新提交代码
git add -u
git commit
git push origin HEAD:refs/for/dev_new_feature
Step1. 在本地仓库中, 更新并合并代码
git fetch origin
git rebase origin/master
Step2. 依据提示分别打开冲突的文件, 逐一修改冲突代码
Step3. 所有冲突都修改完毕后, 提交修改的代码
git add -u
git rebase --continue
Step4. 更新patch
git push origin HEAD:refs/for/master
Git忽略规则:
在git中如果想忽略掉某个文件,不让这个文件提交到版本库中,可以使用修改根目录中 .gitignore 文件的方法(如果没有这个文件,则需自己手工建立此文件)。这个文件每一行保存了一个匹配的规则例如:
此为注释 – 将被 Git 忽略
.sample # 忽略所有 .sample 结尾的文件
!lib.sample # 但 lib.sample 除外
/TODO # 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO
build/ # 忽略 build/ 目录下的所有文件
doc/.txt # 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt
.gitignore规则不生效的解决办法
把某些目录或文件加入忽略规则,按照上述方法定义后发现并未生效,原因是.gitignore只能忽略那些原来没有被追踪的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的。那么解决方法就是先把本地缓存删除(改变成未被追踪状态),然后再提交:
git rm -r --cached .
git add .
git commit -m ‘update .gitignore’
git checkout --patch origin/master src/rinex_nav_io.cpp
git rebase的使用教程
https://blog.csdn.net/zhangxing52077/article/details/88079773
https://blog.csdn.net/qq_21989939/article/details/79787417