git 中级语法

173 阅读4分钟

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 文件;