Git 命令

目录

分支策略

一、分支操作

1、查看分支

2、切换本地分支

(1)本地分支已存在

(2)本地分支不存在

3、本地创建分支

(1)本地分支不存在

(2)本地分支已存在

4、本地创建分支-强制创建

5、合并分支

6、推送分支

(1)正常推送

(2)强推

(3)冲突

7、删除分支

(1)删除本地分支

(2)删除远程分支

8、拉取远程代码到本地(更新本地代码)

(1)正常的拉取(获取远程最新代码,合并到本地)

(2)强制拉取(获取远程最新代码,并覆盖本地文件)

9、暂存代码

10、更新本地的 远程分支列表

11、给分支添加注释

二、其他命令

1、提交 并 添加备注

2、修改commit 的备注信息

3、通过命令 删除 远程仓库 文件夹 或 文件


分支策略

​​​​​把工作空间,从开发主线上分离出来,以免影响开发主线

        Master分支,一般为主分支,应该是最稳定分支,用来打包发布。一般不允许在此分支上进行开发,日常的开发工作需要新建分支(一般命名为dev),在dev分支开发完成并测试通过后(稳定后),可以执行合并dev分支代码到Master分支上。


一、分支操作

1、查看分支

查看 本地分支 及 本地缓存 的 远程分支

git branch -a 

Git中 * 标识的分支,为你当前所在分支
Idea中,黄色星星标识的为主分支(本地及远程)

2、切换本地分支

git checkout 分支名   

(1)本地分支已存在

        会直接切换到本地的dev分支上,此时代码展示的为本地的dev上的

(2)本地分支不存在

        会提示无法匹配到一致的分支

3、本地创建分支

仅仅创建新分支,是不会被计入Contribution。

git checkout -b 分支名   

(1)本地分支不存在

        相当于创建并切换:

                a.创建新的本地dev分支;

                b.将 当前分支代码 复制到dev分支上;

                c.切换到dev分支。

        此时dev上的代码与当前分支上的代码完全相同。

等同于依次执行以下两步:
    (a):git branch dev       创建新的本地dev分支  并把当前master代码复制到dev上
    (b):git checkout dev     切换到dev分支

(2)本地分支已存在

        提示创建失败,此分支已存在

4、本地创建分支-强制创建

git checkout -B

        强制创建新的分支,如果当前仓库中,已经存在一个跟你新建分支同名的分支,那么使用普通的 git checkout -b 这个命令,是会报错,且同名分支无法创建。如果使用-B参数,那么就可以强制创建新的分支,并会覆盖掉原来的分支代码。

5、合并分支

    例如,将 dev 分支代码 合并到 master 分支,则需本地先切换至 master 分支 后,执行以下操作

git merge dev

6、推送分支

(1)正常推送

1、远程 没有 dev 分支 ,且 本地已经切换到 dev 分支(相当于创建远程的dev分支)
执行:
    git push origin dev:dev
    或:
    git push origin HEAD -u

例如:将当前master分支代码推送到master-20191009分支上,如果新分支不存在,则创建并推送
执行:
    git push origin master:master-20191009   
    或:
    git push origin HEAD -u

注意:仅仅创建新分支,是不会被计入Contribution。




2、远程 已有 dev 分支 ,且 远程dev分支 未关联 本地dev分支  且本地已经切换到 dev
执行:
    git push -u origin dev




3、远程 已有 dev 分支 ,且 远程dev分支 已关联 本地dev分支  且本地已经切换到 dev
执行:
    git push 
    或
    git push origin dev

(2)强推

        远程dev分支代码 领先于 本地dev分支代码, 且此领先部分需要去除,此时本地dev分支代码中不存在 远程dev分支领先的代码,则无法进行删除,此时就要将 本地dev分支的代码 强行推送  覆盖掉远程dev分支代码

    (a)本地所在分支 即为想要强推的分支

git push -f

    (b)本地所在分支 不是想要强推的分支。(将 pre 分支代码到 强推至 master,既覆盖掉master代码)

$ git push -f origin 源分支:目标分支

$ git push origin 源分支:目标分支 -f  

(3)冲突

不同的开发人员对统一段代码进行修改,后推送的人会报错(如下图)

idea中显示如下:

<<<<head 与 ====== 之间 的内容 为你在本地编辑的内容,
======== 与 >>>>>>>之间的 为远程仓库中的内容

选择保留哪个 然后 依次执行

git add .     

git commit -m "备注信息"    

git push origin master

7、删除分支

(1)删除本地分支

        仅删掉了branch的指针,并未直接改变history log的结构

git branch –d dev

(2)删除远程分支

git push origin --delete dev

注意:
        执行 git branch -d XX  可能提示:  the branch  XX is not fully merged

原因:

        XX分支有没有合并到当前分支的内容

解决方法:

        使用大写的D 强制删除  git branch -D XX

  

另外:

        不能删除当前 checkout 的分支

其它:

        删除远程分支 需要切换到其它分支之后删除当前分支

否则会:

        error:cannot delete the branch 'XXX' which you are currently on

8、拉取远程代码到本地(更新本地代码)

引用一个他山之石:git fetch & pull详解 - Runner_Jack - 博客园

(1)正常的拉取(获取远程最新代码,合并到本地)

(a)本地 拉取 与远程 是同一个分支的代码

git pull origin dev

// 从远程主机的master分支拉取最新内容 
git fetch origin master


// 将拉取下来的最新内容合并到当前所在的分支中
git merge FETCH_HEAD

(b)本地 拉取 与远程 是不同分支的代码

将远程主机的某个分支的更新取回,并与本地指定的分支合并

git pull <远程主机名> <远程分支名>:<本地分支名>

 如:本地的当前分支为master,则此时会将dev的代码合并到master上

git pull origin dev:master

(2)强制拉取(获取远程最新代码,并覆盖本地文件)

        (a)从远程下载最新的,而不尝试合并或rebase任何东西

git fetch --all

        (b)git reset 将主分支重置为您刚刚获取的内容。 --hard选项更改工作树中的所有文件以匹配origin/master中的文件。

git reset --hard origin/master

或者如果你在其他分支上:

git reset --hard origin/<branch_name>

9、暂存代码

 (a)将本地新写的代码暂时的截取,并存储在缓存空间。执行此命令后 当前所写的代码会消失。

git stash

(b)将截取在缓存空间中的代码 释放出来  此命令如果不是在git stash之后使用,会释有一些奇奇怪怪的问题 

git stash pop 

10、更新本地的 远程分支列表

git remote update origin --prune

git remote update origin -p

11、给分支添加注释

git config branch.分支名称.descripiton '注释内容'

 查看分支注释,可添加git工具 git-br

//npm 下载
npm i -g git-br

 查看时,执行命令


二、其他命令

1、提交 并 添加备注

git commit -m "备注信息"

2、修改commit 的备注信息

前提:在 push 操作 

// 取消上一次提交,并且将暂存区的文件重新提交。也可以不修改内容,仅对描述进行修改。
git commit --amend

第一次的提交信息:

修正操作:执行 git commit --amend 命令,会出现下面的图例,其中黄色文字,为待修改的备注信息,直接删除重新编写;

保存操作:信息内容修改后,执行命令  英文冒号 : ,后输入wq 或  q(“:wq”,表示write , quit :先将修改写到文件,然后退出)此时页面会跳转,之后可以执行正常的 push 操作

结果:

3、通过命令 删除 远程仓库 文件夹 或 文件

提交时忘记忽略 target* ,导致 target文件夹及下属文件 上传到远程仓库,在github上只能删除仓库,却无法删除文件夹或文件, 所以只能通过命令来解决

(a)使用dir命令,查询当前目录结构

(b)使用cd命令,进入对应子模块center,并再次使用dir命令,查询当前层目录结构,可以看到target文件夹

(c)在target所在目录层下,执行以下命令,进行删除操作

$ git rm -r --cached target  删除target文件夹

(d)之后就是提交 并push到远程

$ git add .
$ git commit -m '删除了target'  提交,添加操作说明
$ git push origin master 将本次更改更新到github项目上去

(e)查看远程仓库,发现文件夹已消失

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值