Git
执行Git init命令后为什么没有分支,因为没有commit,git分支必须指向一个commit,没有任何commit就没有任何分支。
远程操作命令
- git config --list
- git remote remove origin; //删除远程仓库
- git remote -v //详细列出已存在的远程分支
- git remote add origin git@github.com:test/learngit.git //添加远程仓库
stash 用于修改了代码不想提交,但需要切换分支的场景
- git stash //回滚到修改前并暂存修改内容
- git stash apply //从stash list中拿到应用stash中的内容,但是stash还会存在stash list中
- git stash pop //从stash list中拿到应用stash中的内容,会从stash list中删除stash
- git stash list // 显示所有的stash内容
- git stash clear //清空stash list中所有stash
- git stash drop stash@{0} //这是删除第一个队列
合并某分支到当前分支
git merge [name]
选择一个commit,并入当前分支
git cherry-pick [commit]
新建分支
- git branch [branch-name] //新建一个分支,但依然停留在当前分支
- git branch branch_name remote_name/branch //基于远程仓库创建新分支
- git checkout -b branch_name remote_name/branch //基于远程仓库创建新分支并且切换到新分支
- git checkout -b [BRANCH-NAME] [REMOTE-NAME]/[BRANCH-NAME]
重置当前分支
- git reset [commit] //重置当前分支的指针为指定commit,同时重置暂存区,但工作区不变
- git reset --hard [commit] //重置当前分支的HEAD为指定commit,同时重置暂存区和工作区,与指定commit一致
- git reset --keep [commit] //重置当前HEAD为指定commit,但保持暂存区和工作区不变
- 修改remote.origin.url值,需要更改项目路径下的.git/config文件
工作中问题
7月12遇到的问题,代码出现问题,需要回退版本,回退历史版本的操作:
- git reset --hard 75ba5b3e87c0d6ae88fab888c759f0c9ee2fc646 //本地代码库操作 回退到一个版本
- git push origin master —force //本地代码库操作 强制推送代码到远程分支
- git fetch origin 、git reset --hard origin/master //在其他代码库操作 执行这两个命令 才能强行同步到远程代码 跟远程代码同步
添加一个远程仓库,独立管理
命令为:git remote add name url
示例:
- 指定一个默认的远程库 origin
- 新增一个远程库 git remote add tina github.com/tingtingtin…
- 如果要同步到 远程库 tina 中 需要手动指定仓库别名 git push tina
$ git remote -v
origin http://git.xxx (fetch)
origin http://git.xxx (push)
tina https://github.com/tingtingtina/xxx.git (fetch)
tina https://github.com/tingtingtina/xxx.git (push)
\
.gitignore文件 明明写好了规则,但问题不起作用,每次还是重复提交,无法忍受。
解决办法 git rm -r --cached . git add . git commit -m 'update .gitignore' //windows 使用的命令是
其实.gitignore这个文件里的规则对已经追踪的文件是没有效果的,所以我们需要使用 rm 命令清除一下相关的缓存内容,这样文件将以未追踪的形式出现,然后再重新添加提交一下 .gitignore 文件里的规则就可以起作用了。
Git忽略规则匹配语法
在 .gitignore 文件中,每一行的忽略规则的语法如下:
空格不匹配任意文件,可作为分隔符,可用反斜杠转义;
开头的文件标识注释,可以使用反斜杠进行转义;
! 开头的模式标识否定,该文件将会再次被包含,如果排除了该文件的父级目录,则使用 ! 也不会再次被包含。
/ 结束的模式只匹配文件夹以及在该文件夹路径下的内容,但是不匹配该文件;
/ 开始的模式匹配项目跟目录;
如果一个模式不包含斜杠,则它匹配相对于当前 .gitignore 文件路径的内容,如果该模式不在 .gitignore 文件中,则相对于项目根目录;
** 匹配多级目录,可在开始,中间,结束;
? 通用匹配单个字符;
* 通用匹配零个或多个字符;
[] 通用匹配单个字符列表;
- 常用匹配示例
bin/ 忽略当前路径下的bin文件夹,该文件夹下的所有内容都会被忽略,不忽略 bin 文件;
/bin 忽略根目录下的bin文件;
/*.c 忽略 cat.c,不忽略 build/cat.c;
debug/*.obj 忽略 debug/io.obj,不忽略 debug/common/io.obj 和 tools/debug/io.obj;
**/foo 忽略/foo, a/foo, a/b/foo等;
a/**/b 忽略a/b, a/x/b, a/x/y/b等;
!/bin/run.sh 不忽略 bin 目录下的 run.sh 文件;
*.log 忽略所有 .log 文件;
config.php 忽略当前路径的 config.php 文件;