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)查看远程仓库,发现文件夹已消失

<think>好的,我现在需要帮助用户了解Git命令的使用教程和常见命令列表。首先,用户提到想学习Git命令的用法,可能需要基础命令的介绍和一些实际例子。根据用户提供的引用内容,我应该优先包含git config、git add、git commit、git push这些基本命令,因为这些在引用中都有提到。特别是引用1详细介绍了git config和git add的使用,引用3提到了git push的简化操作。 接下来,我需要确保结构清晰,按照用户的要求分步骤讲解。可能的结构是:安装配置、基本工作流程、分支管理、远程仓库操作、其他常用命令。每个部分下给出具体的命令和示例,比如在配置部分,引用1和引用2都提到了git config的使用,包括设置用户名、邮箱和查看配置列表,这些都需要包含进去。 另外,用户示例中的Python代码块提醒我需要用代码块格式展示Git命令,但注意用户的问题是关于Git的,所以应该用命令行代码块,如```bash。同时,需要检查LaTeX格式是否正确,不过这个问题中可能用到的数学公式不多,但如果有的话,比如在解释某些概念时,可能需要使用行内公式,比如$ git add $这样的变量?不过Git命令本身不需要数学公式,所以可能不用,但需要留意系统指令中的要求。 用户还要求生成相关问题,我需要根据内容提出相关问题,比如如何撤销提交、分支管理策略等,这些是用户可能进一步想了解的。 需要确保引用的正确使用,每个引用对应的内容要准确。例如,引用1提到git add .,引用3提到git push -u origin master,这些都要在相应部分标注引用标识。同时,用户提供的引用中没有提到git commit、git status等命令,但这些属于常见命令,可能需要补充,但因为没有引用来源,可能需要避免引用标记,或者如果用户提供的引用中确实没有,可能需要不标注引用,但根据用户给出的引用,只能使用现有的三个引用。 不过,用户提供的引用中,引用1提到了git config和git add,引用2是git config --list,引用3是git push。所以当提到这些特定命令时,添加对应的引用标记,其他命令git commit、git status可能没有引用来源,就不添加引用标识。 最后,生成的相关问题应该围绕Git的进一步学习,比如配置管理、撤销操作、分支合并冲突解决、.gitignore文件使用等,这些都是用户可能感兴趣的点。 现在开始组织内容: 1. 安装与配置:根据引用1和2,介绍git config设置用户信息,查看配置。 2. 基本工作流程:git init, git add(引用1), git commit, git status, git log。 3. 分支管理:git branch, git checkout, git merge。 4. 远程仓库:git remote add, git push(引用3), git pull。 5. 其他命令git clone, .gitignore, git reset(可能没有引用来源,但常见)。 在写作时,确保每个命令的示例正确,比如git add . 来自引用1,要标注[^1]。git config --list来自引用2,标注[^2]。git push -u来自引用3,标注[^3]。 可能还需要检查是否有其他命令在引用中提到,但根据提供的三个引用,主要涉及config、add、push。因此,其他命令可能没有引用来源,但用户的问题需要常见命令列表,所以必须包含,但引用标记只用在对应的部分。 最后生成相关问题,如如何撤销提交、解决合并冲突、配置忽略文件等。</think>### Git 常用命令使用教程 Git 是分布式版本控制系统,以下是基础命令和常见用法: --- #### 一、安装与配置 1. **配置用户信息**(提交时标识身份) ```bash git config --global user.name "你的用户名" git config --global user.email "你的邮箱" ``` 此配置会保存在全局文件(如 `~/.gitconfig`)。 2. **查看当前配置** ```bash git config --list ``` 可检查所有生效的配置项。 --- #### 二、基本工作流程 1. **初始化仓库** ```bash git init ``` 2. **添加文件到暂存区** ```bash git add <文件名> # 添加单个文件 git add . # 添加所有修改和新文件 ``` 3. **提交更改** ```bash git commit -m "提交说明" ``` 4. **查看状态与日志** ```bash git status # 查看工作区和暂存区状态 git log # 查看提交历史 ``` --- #### 三、分支管理 1. **创建与切换分支** ```bash git branch <分支名> # 创建分支 git checkout <分支名> # 切换分支 git checkout -b <分支名> # 创建并切换 ``` 2. **合并分支** ```bash git merge <目标分支> ``` --- #### 四、远程仓库操作 1. **关联远程仓库** ```bash git remote add origin <仓库URL> ``` 2. **推送代码** ```bash git push -u origin master # 首次推送需指定分支[^3] git push # 后续推送可简化 ``` 3. **拉取更新** ```bash git pull origin master ``` --- #### 五、其他常用命令 | 命令 | 用途 | |------|------| | `git clone <仓库URL>` | 克隆远程仓库到本地 | | `git reset <文件>` | 撤销暂存区的修改 | | `git diff` | 查看文件差异 | ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值