git for windows_手把手教会舍友玩 Git (包教包会,再也不用担心他的学习)

作 者: BWH_Steven

原文链接:https://www.cnblogs.com/ideal-20/p/13644420.html

4406c30e474724a8c444fbe14a0b96f4.png

舍友长大想当程序员,我和他爷爷奶奶都可高兴了,写他最喜欢的喜之郎牌Git文章,学完以后,再也不用担心舍友的学习了(狗头)哪里不会写哪里 ~~~

一 先来聊一聊

太多东西属于,总在用,但是一直都没整理的东西了,从刚接触编程那会,就学着各种教程的进行 ”点击“ ,”输入“,Git 也算一个老生常谈的内容,想用好也没那么容易,这一篇从前因,以及下载安装、配置,以及实际的上手方式,整理了出来,不过还是要说,这一篇适合没接触过 Git ,以及 Git 运用不是很熟练的朋友,我用了大量的文字以及图片进行了说明,有些朋友可能会感觉头晕哈哈哈,我感觉,看完起码对于一个新手朋友来说还是有一定帮助的。

不过想进阶,以及想看大量命令的朋友就不太适合了,毕竟这是一篇类似保姆级的入门文章

(1) 为什么要用版本控制?

不管是学生时期,亦或者工作了,有时候免不了需要写一些文档,例如你交一份报告给你的指导老师, 最终通过的报告,总是在不断沟通与修改中完成的,例如 V1、V3、V5 是传给老师的版本,老师标注错误后会回退给我一个偶数的版本,即 V2、V4、V6,这就是版本的一个通俗的概念

952b333f102f1e8002819daef555a679.png

而在开发的过程中,随着开发进度的进行,软件的版本也同样需要不断的进行迭代,不管你的代码迭代只进行在你本地,亦或者特定的服务器上,如果按照刚才提交报告的形式进行迭代,就会出现一个问题:即每一个版本中大量代码是重复的

那再想想办法,使用最新的内容替换掉原先旧的版本,或者只保留最新版本以及最新版的前一个版本

但是新问题又出现了:代码重复确实少了,但是如果多个人同时修改,编辑这个文件,更会出现更多冲突与问题

要考虑的东西太多了,有没有一种比较东西可以帮助我们呢?

这就是版本控制这个概念以及相关技术出现的一种原因了

(3) 版本控制简介

版本控制最主要的功能就是追踪文件的变更。它将什么时候、什么人更改了文件的什么内容等信息忠实地了记录下来。每一次文件的改变,文件的版本号都将增加。除了记录版本变更外,版本控制的另一个重要功能是并行开发。软件开发往往是多人协同作业,版本控制可以有效地解决版本的同步以及不同开发者之间的开发通信问题,提高协同开发的效率。并行开发中最常见的不同版本软件的错误(Bug)修正问题也可以通过版本控制中分支与合并的方法有效地解决。

所以,需要对内容版本迭代进行管理,以及多人协作时一定需要使用版本控制

(二) 版本控制软件

工欲利其事必先利其器,有这种需求,自然也不用担心,没这种产品,目前常见的版本控制产品很多,不过作为一名开发人员,其实听到最多的还是 Git 和 SVN,来看看区别

(1) 集中版本控制:SVN

SVN是集中式版本控制系统,也就是说,所有版本的数据都是存放在服务器上的,每次要做什么事情,每个人都是使用自己的电脑,去向中央服务器进行拉取最新的版本内容,完事后再推回去新版本,但是这个行为需要联网的支持,没有网络的情况下,用户只能看到本地以前同步过的内容,无法查看历史版本,这种方式,会受到网络,以及服务器损坏导致数据丢失的掣肘

639871f4d8a69b2c674a1fac054603bd.png

(2) 分布式版本控制:Git

Git 大家应该很熟悉了,或多或者也都有用过,还有马上能联想到的 GitHub、GitLab、Gitee

Git是分布式版本控制系统,换句话说,它没有像 SVN 那样的中央服务器,它最大的特点就是所有版本信息仓库都会同步到每个用户的电脑中,这样每个人即使在本地也可以查看所有历史的版本,没有联网的情况,也可以在本地的仓库提交,联网时 push 即可,一定程度上解决了前面 SVN 遇到的一些问题

5032fe29c77707768ba3cb7731d71b49.png

(三) Git 历史

感兴趣的简单看看就行了,直接贴的,略过也行

同生活中的许多伟大事件一样,Git 诞生于一个极富纷争大举创新的年代。Linux 内核开源项目有着为数众广的参与者。绝大多数的 Linux 内核维护工作都花在了提交补丁和保存归档的繁琐事务上(1991-2002年间)。到 2002 年,整个项目组开始启用分布式版本控制系统 BitKeeper 来管理和维护代码。

到 2005 年的时候,开发 BitKeeper 的商业公司同 Linux 内核开源社区的合作关系结束,他们收回了免费使用 BitKeeper 的权力。这就迫使 Linux 开源社区(特别是 Linux的缔造者 Linus Torvalds )不得不吸取教训,只有开发一套属于自己的版本控制系统才不至于重蹈覆辙。他们对新的系统订了若干目标:

  • 速度
  • 简单的设计
  • 对非线性开发模式的强力支持(允许上千个并行开发的分支)
  • 完全分布式
  • 有能力高效管理类似 Linux 内核一样的超大规模项目(速度和数据量)

二 下载安装 Git

我这边本来就装着一个旧版本的 Git,为了演示截图,重新装一下,卸载很简单,只需要把环境变量给清了,然后安装目录或者控制面板删除就行了

(一) 下载

下载先考虑的当然是官网:https://git-scm.com/

直接点击右下角的 Download,跳转后选择适合自己的系统版本就行了

2ee701f81ee88a293834901a17a4759d.png

不过官网下载毕竟还有个墙的问题,要么一直转圈,要么就下载极其缓慢

那么淘宝镜像下载地址就又来了:http://npm.taobao.org/mirrors/git-for-windows/

  • 选择版本,例如:v2.28.0.windows.1
  • 选择适合自己系统文件:例如:Git-2.28.0-64-bit.exe

下图为淘宝镜像中选择版本图

4a43b3bfc7ee7e70c48deb49cbab845a.png

(二) 安装

点击下载好的安装程序,刚打开就是一个许可声明,直接下一步就行了,接着就是选择安装路径,选择一个适合的安装位置

首先选择要安装的组件,保持默认即可,没勾选的内容,是关于是否在桌面创建快捷方式,以及是否在控制台中使用 TrueType 字体以及是否每天检查 Git (Windows)更新的

9d2bd0b1231e8e21bd67a8bcd9dd2681.png

这一步是选择开始菜单的文件夹名称,直接下一步

244c2725da67798d5c26c672a8690480.png

这一步用来选择 Git 默认的编辑器,默认是 Vim 选择自己用的例如 sublime 、vs code 都可以,这个地方用的不是太多,用默认倒也可以

406643bc3b92b350d8950f4895ce99ef.png

这一项选择第二个

43fdf6e197aa67bc61e8ed86344a9936.png

选择 HTTPS 的后端传输,选择第一项 OpenSSL 库

ee926d3e2fb1aa21f9744347278e5cf8.png

这是用来配置行尾符号装换的,在 Win 上我们一般推荐使用第一个选项

c53085b52a1a559854fe742f38acf355.png

这里就是用来配置你最后使用 Git Bash 的时候,是使用MinTTY(MSYS2的默认终端)还是 Win 默认的 cmd.exe,但是使用前者可以调整大小窗口,以及使用Unicode字体等特点,后者在某些方面有一些掣肘,所以我们选择第一项

8dd4a53422c2024f1399d14fbdafdd6e.png

关于 pull 时候的处理,选择默认即可,pull 后面会讲

465ad755afbf54aca78d4b76f33b88d8.png

这里选择第二个选项,即 "启用Git凭证管理器" Windows的 Git 凭证管理器为 Windows 提供安全的Git 凭证存储

a5ed67054dc17d596f7a3f6e8440de7e.png

下面的第一个选项是 "启用文件系统缓存",文件系统数据将被批量读取并缓存在内存中用于某些操作(“core.fscache”设置为“true”),这提供了显著的性能提升。

第二个选项是 "启用符号链接",启用符号链接(需要SeCreateSymbolicLink权限),不过,现有存储库不受此设置的影响

所以选择第一项即可

8ff3f3d2ae01faced9a02615e972c316.png

这一项不勾选,是一些额外的支持,不一定用得到,且看提示尚存未知 bug

6c0c13365a7d0d3716afb32af3d138da.png

直接点击安装就可以了

(三) 验证安装

安装后,首先开始菜单中会有提示最近添加的内容,同时在任意文件夹下右键也会多出两个选项,Git GUI Here、Git Bash Here,同时它会默认帮我们配置环境变量

64415143631c951eaa2243969b602b05.png

例如我右键点击 Git Bash Here,就会弹出,同时输入一些基本命令后,也是有反应的

da6dd7a846cd944f31ae48123974d0b1.png

Git Bash:Unix 与 Linux 风格的命令行,这是一般最常用的

Git CMD:Windows风格的命令行(长得就和 cmd 差不多)

Git GUI:图形界面的Git,不建议入门学习使用,学习还是以学习命令为主,再考虑图形界面

说明一下:使用 git 会涉及到一些常见的 Linux 命令,不过因为使用者是基于像 Windows 这样拥有图形界面的系统,所以也不用每次使用都通过 cd ,直接通过文件夹,右键点开也是可以的,不过Linux 常见的命令还不会的话,建议还是先看一下 Linux 的入门语法

我好像以前写过一篇,Linux 的安装还有详细入门命令的文章,有兴趣可以看一下,想了解更多,可以去度娘一下或者找个教程系统学一下

三 Git 配置和基本理论

(一) 配置

Git 有两种配置文件,一种是系统级别的配置文件,还有一种是用户级别的配置文件,且这两者都存储在本地上,先看一下如何显示所有配置文件内容(注:下面是小写 L 不是数字1或者 大写 i)

git config -l
c7ef96b6b70861d2244c4a9d5c719226.png

上述就是杂糅在一起的内容,都查出来了,如果想要分别查看不同的配置文件,也是有办法的

# 查看系统配置git config --system --list  # 查看当前用户配置git config --global  --list

这里大家可以分别尝试一下

配置都是存在本地的,那么文件的位置在哪里呢?

  • 系统配置:XXXGitetcgitconfig 例如 D:developGitetcgitconfig
  • 用户配置:C:甥敳獲用户名 .gitconfig
  • 注意:别忘记显示文件夹中的隐藏文件,否则看不到 .gitconfig

如果是第一次使用,应该是没有 .gitconfig ,以前如果用过,或者折腾过例如 hexo 等内容,应该都是配过的,例如我这台机器的 .gitconfig 中的内容如下:

[user]    name = ideal-20    email = ideal_bwh@163.com[i18n]    commitencoding = utf-8    logoutputencoding = utf-8[gui]    encoding = utf-8

我在其中配置定义了一个 user ,写入了我的 name 和 email, 这个工作还是非常推荐做的,因为你后面提交内容的时候,就会默认的使用配置,不用填写了

上面是直接修改文件的方式,如果想要使用 git 命令配置,则如下:

git config --global user.name "ideal"  #名称git config --global user.email ideal_bwh@163.com   #邮箱

其他的一些编码配置,可以后面根据需要配置也可以

小结:要认识基本配置,最好配置用户名和邮箱作为你这个用户的标识,命令中如果传入--global 也就是告诉 Git 每次默认都用这个内容代表你这个用户,如果你在某个项目中不想使用这个标识,你可以在项目中再次执行此语句,但是不传入 --global 就可以了

(二) 基本理论

(1) Git 工作区域

工作区域这个概念是非常重要的,要留心一下

你想从本地上传一份代码到 github,不同的阶段下,你想上传的内容,会处于不同的位置区域中,Git 的工作区域就分为四大块

  • 工作区(Workspace / Working Directory)
  • 暂存区(Stage / Index)
  • 本地仓库(Git Directory / Repository)
  • 远程仓库(Remote Directory / Remote)

工作区:本地项目文件存放位置,也就是你放这个项目代码的地方

暂存区:暂存字面意思就是临时存放的意思,这里用来临时存放你的改动,虽然叫做 XX区 ,但是本质上只是一个文件,其中记录了文件的名称、时间戳、长度等内容

本地仓库:暂存区的内容可以通过命令提交到本地仓库,所以它存放你提交所有提交版本的数据

远程仓库:用来托管代码的远程服务器,供使用者拉取等操作

若仅仅从使用的角度出发,其实我们更需要关注的点在于工作区和远程仓库

虽然到现在,可能对于几大工作区域还是有点懵,不过稍后提到他们之间的关系,以及一些讲解命令,变更当前欲提交代码位置的时候,就会明白了

(2) Git 流程 / 区域间关系

上面书写几个区域流程的时候,其实已经是按照一定的顺序来写了

Git 工作时执行的流程如下:

  • 先在工作区中添加或者修改一些文件,说白了就是写完代码,或者修改了旧代码
  • 将需要最终提交到 Git 管理的文件存放入暂存区
  • 暂存区中的文件提交到本地仓库中
  • 本地仓库中的修改推送到远程仓库
5c609ac2915c31661d402fe9e78531d7.png

上面我们介绍的流程,就是图中从 add 到 commit 到 push 的一个过程,也就是从工作目录到远程仓库的一个过程

上面的一些内容,就是关于项目从云端拽到本地等等,下面这些命令我们都会提到

下面手把书开始进行 Git 项目的创建,以及如何上传以及拉取项目

(三) 创建/克隆仓库

如果你想要在本地上生成一个仓库,要么就是直接创建一个新的本地仓库,要么就是从云端可克隆一个远程仓库

(1) 本地仓库的创建

在当前的目录下了,初始化一个新的仓库

git init

例如我在桌面的 git-stuty 文件夹中打开 git-bash

94b6479a03efcc1ba4103a7edc45a91c.png

它会提示初始化了一个空的 Git 仓库在你这个路径下,同时可以在这个文件夹中,直接看到有一个名为:.git 的文件夹出现,默认会有一些初始化的文件在其中

(2) 远程仓库的克隆

第二个方法就是直接克隆远程项目,命令为

git clone [url]

其中的 [url] 部分直接替换成在 Github 或者 Gitee 等上面拿到的克隆地址,Github 实例如下

ec8ddb44270c3c011b6fb525eb9c9992.png

怎么选择呢?一般来说,如果我们是一个全新的项目或者说一个Demo想要上传到 Github 等这种平台,就需要在项目目录下创建一个 Git 仓库,而如果你想看别人的项目,就直接克隆下来,或者你在别的电脑上想要继续写自己的一个远程存储的项目,你也可以克隆下来

通常一种做法就是,先在远程创建仓库,然后拉取到本地来做

(四) 文件状态及忽略文件

(1) 文件状态

等下我们会带着大家走一遍实操流程,但是我们还需要补充两个点,因为后面我们实操会用到

  • Untracked:未跟踪状态,此文件还在你的项目文件夹中,但是还没添加到 Git 仓库中,所以还不受到版本控制,例如编写一个 HelloWorld.java 文件,但是还没做什么操作,只有这么一个文件而已
  • 最后通过 git add 命令后,状态变为 Staged
  • Staged:暂存状态,但还没有真正入库
  • 执行 git commit 命令后,会把你修改的内容,和本地仓库中进行同步,同步后,这时本地仓库中的文件和本地文件又变为一致, 文件就会变成 Unmodify 状态
  • 如果想执行取消这种暂存状态,只需要执行 git reset HEAD filename 命令取消暂存, 文件状态会为 Modified
  • Unmodify:文件已入库,同时版本库(.git )中的文件快照内容与文件夹中完全一致
  • 如果它被修改, 而变为 Modified, 如果使用 git rm 移出版本库, 则成为Untracked 文件
  • Modified:文件已修改,不过仅仅是修改,没有进行其他的操作
  • git add 可进入暂存 Staged 状态, 使用 git checkout 则丢弃修改过, 返回到unmodify状态, 这个git checkout即从库中取出文件, 覆盖当前修改

(2) 忽略文件

这块内容,在 IDEA 中应该都有见过,即:.gitignore 文件,其中的内容,就是我们选择要进行忽略的文件,也就是说,这些东西,我们不想纳入版本控制中,例如 sql 文件,或者一些临时文件,直接贴了一份规则

说明:这一块,没仔细整理,或许是有出入的,想深入了解,更推荐去找一份专题的博文

  • 忽略文件中的空行或以井号(#)开始的行将会被忽略。
  • 可以使用Linux通配符。例如:星号(*)代表任意多个字符,问号(?)代表一个字符,方括号([abc])代表可选字符范围,大括号({string1,string2,…})代表可选的字符串等。
  • 如果名称的最前面有一个感叹号(!),表示例外规则,将不被忽略。
  • 如果名称的最前面是一个路径分隔符(/),表示要忽略的文件在此目录下,而子目录中的文件不忽略。
  • 如果名称的最后面是一个路径分隔符(/),例如 file/ 表示忽略目录file下的全部内容,不管是根目录下的/file/目录,还是某个子目录/child/file/目录,都会被忽略

举个例子:

*.class#package file*.war*.ear#kdiff3 ignore*.orig#maven ignoretarget/#eclipse ignore.settings/.project.classpatch#idea.idea//idea/*.ipr*.iml*.iws# temp file*.log*.cache*.diff*.patch*.tmp# system ignore.DS_StoreThumbs.db

四 手把手使用 Git

前面该铺垫的内容基本都扯到了,下面手把手试一试,分为两种方式,一种是直接使用命令行,一种就是在 IDEA 中使用图形界面

要说明一下,命令行的方式,并不是仅仅只能在文件夹中使用,更多的情况下,我们一般会把 IDEA 的 terminal 配置我们的 git-bash,这样,我们在 IDEA 中,编写或者修改代码后,就可以直接通过 Git 命令进行提交,我们下面演示的两种方式也都是基于 IDEA 的

(一) 使用 GitHub/码云

不管怎么样,一个 Git 代码托管平台的账号总是要有的,针对个人来说用的比较多的,还是 GitHub,当然国内的码云(Gitee),胜在速度快,GitHub或许就需要使用一些科学的上网方式才能有比较好的速度体验了,还有一个就是 GitHub 是全英文的,后者则为中文

没有账号的小伙伴,注册一个就好了,下面为了照顾所有童鞋,顺便提一下配置 SSH 公钥

说明:为了快一点,我使用码云来进行演示,GitHub 同理

配置 SSH 公钥,也就是可以帮助我们实现免密码登录,否则,我们每一次和远程仓库进行一些操作,都需要输入账号密码

  • 进入 C:甥敳獲用户名.ssh 目录下
  • 如果没有用过 ssh 这里是没有内容的,需要生成
ssh-keygen -t rsa

ssh-keygen 就是生成公钥的命令,后面是指定了加密方式,一般这样写就可以

执行后,控制台会显示一些不规则的图画,接着文件夹中会生成两个文件

  • id_rsa.pub 和 id_rsa

带有 pub 后缀的就是代表公钥,另一个就是私钥

用编辑器打开公钥代码,全部复制,接着打开码云中安全设置中的的 SSH 公钥配置,将公钥复制进去,它会默认填充标题,这样就好了

使用SSH公钥可以让你在你的电脑和码云通讯的时候使用安全连接(Git的Remote要使用SSH地址)

868ac3ad714020945bc03894466d2803.png

(二) 修改 IDEA Terminal

可以直接在 Idea 里的Terminal里面进行 git命令的输入,当然需要把原先的 cmd 修改为 Git 下的 bash,注意:不要设置为 git-bash 否则只能弹窗使用

22efd8d985c7b3be3cf966c116388132.png

做完也可以顺便创建一个 readme文件:$ touch README.md 不过无所谓啦,一般直接在 GitHub 等上也能直接生成

(三) 向远程仓库提交代码(命令方式)

说明:我把我这边的执行结果也贴上了,本质命令也就那么几句

1、创建项目,或打开欲上传项目

2、在下方 Terminal 中执行 git init 进行空仓库的初始化,如下(别复制 $ 符号啊):

abc@LAPTOP-5T03DV1G MINGW64 /f/develop/IdeaProjects/temp/git-study (master)$ git initInitialized empty Git repository in F:/develop/IdeaProjects/temp/git-study/.git/

3、可以使用 git status 查看当前的状态,可以看到,可以看到当前还没提交

abc@LAPTOP-5T03DV1G MINGW64 /f/develop/IdeaProjects/temp/git-study (master)$ git statusOn branch masterNo commits yetUntracked files:  (use "git add ..." to include in what will be committed)        .gitignore        .mvn/        mvnw        mvnw.cmd        pom.xml        src/nothing added to commit but untracked files present (use "git add" to track)

4、使用 git add . 将所有添加或者修改过的文件添加到暂存区

abc@LAPTOP-5T03DV1G MINGW64 /f/develop/IdeaProjects/temp/git-study (master)$ git add .warning: LF will be replaced by CRLF in .gitignore.The file will have its original line endings in your working directory..... 省略

5、add 后可以继续使用 git status 查看当前的状态,可以看到,一下这些文件就是被添加到暂存区的

abc@LAPTOP-5T03DV1G MINGW64 /f/develop/IdeaProjects/temp/git-study (master)$ git statusOn branch masterNo commits yetChanges to be committed:  (use "git rm --cached ..." to unstage)        new file:   .gitignore        new file:   .mvn/wrapper/MavenWrapperDownloader.java        new file:   .mvn/wrapper/maven-wrapper.jar        new file:   .mvn/wrapper/maven-wrapper.properties        new file:   mvnw        new file:   mvnw.cmd        new file:   pom.xml        new file:   src/main/java/cn/ideal/DemoController.java        new file:   src/main/java/cn/ideal/gitstudy/GitStudyApplication.java        new file:   src/main/resources/application.properties        new file:   src/test/java/cn/ideal/gitstudy/GitStudyApplicationTests.java

6、使用 git commit -m "提交信息" 提交暂存区中的内容到本地仓库 -m 提交信息

这个提交信息,就是你会在远程仓库中每次看到的提交信息,例如:

d09e778c917ae5bf9e272eec8363edb7.png
abc@LAPTOP-5T03DV1G MINGW64 /f/develop/IdeaProjects/temp/git-study (master)$ git commit -m "first commit"[master (root-commit) 4c9acbe] first commit 11 files changed, 735 insertions(+) create mode 100644 .gitignore create mode 100644 .mvn/wrapper/MavenWrapperDownloader.java create mode 100644 .mvn/wrapper/maven-wrapper.jar create mode 100644 .mvn/wrapper/maven-wrapper.properties create mode 100644 mvnw create mode 100644 mvnw.cmd create mode 100644 pom.xml create mode 100644 src/main/java/cn/ideal/DemoController.java create mode 100644 src/main/java/cn/ideal/gitstudy/GitStudyApplication.java create mode 100644 src/main/resources/application.properties create mode 100644 src/test/java/cn/ideal/gitstudy/GitStudyApplicationTests.java

7、像远程 add git remote add origin 远程仓库地址

abc@LAPTOP-5T03DV1G MINGW64 /f/develop/IdeaProjects/temp/git-study (master)$ git remote add origin git@gitee.com:ideal-20/git-study.git

8、由于是第一次提交,所以需要先将远程仓库的内容拉取下来,直接 push会报错,执行:git pull

9、提交上去:$ git push -u -f origin master 注意:-f 是强制提交,因为可能咱们第一次拉取过后会出现 项目没有刚才采取到的新的错误,以后不加 -f

效果如下:

18b19608fd0169500836a92deeb62053.png

(四) 向远程仓库提交代码(图形界面方式)

1、首先在左侧目录结构中,右键点击项目名,选择 Git Add

6f13b453afeb474d61276c890f60117f.png

2、接着再次点击右键项目名,这次选择 Commit Directory

这个界面,会显示变更的文件,以及让你输入需要上传的提交信息,如果你之前已经配置过用户级别的配置信息,不填写个人信息也行,下面是代码的比对,右侧默认勾着一些检查的勾选,会增加一些时间,也可以全部取消勾选

54f7f6ff30da59f827da7a6ba60e19e2.png

3、在上方菜单栏中有一项叫做 VCS ,点击后 选择 Git 然后选择 Push

e843ea88a9eaa25782c675191459ea36.png

4、然后看到了我们刚才 commit 的内容,选择直接 Push

16a0c1e0e184c6c8e19dd9b4bba2b992.png

5、去仓库看一下,仍然上传成功了

cc3ed20145440f894510c350508bfd5b.png

(五) 补充方式

刚才命令行的方式,我们是在我们创建好的本地 Java 项目中初始化 Git 本地仓库,然后提交到远程仓库,还有一种方式,就是直接克隆远程的空仓库下来,例如克隆下一个名为 test 的文件夹,其中含有例如 .git 、.gitignore 等文件或文件夹,然后将这些内容全部复制到你的 Java 项目的根目录下也是可以的

五 分支开发

分支就是指,例如多人开发中,1.0 的版本后,可能会同时开发其他多个版本,就需要的分支的概念,还例如,你在项目中对于一个问题的解决方案还不能保证完美,但你又不想影响正常的内容,所以,你可以在分支上进行开发,而不影响主干

所以为了不影响别人开发以及主干的稳定,所以你可以创建一个属于自己的分支,保证分支上没有问题了,再合并到主干上

1、在master上创建分支 v1.0:$ git checkout -b v1.0 origin/master 并且默认使用它

2、将分支推到远程仓库:$ git push origin HEAD -u

这样我们的远程仓库中就会多出一个分支 v1.0

b1a395c31afcb97a61c92caf38d5f44b.png

3、给这个分支提交一个内容,信息为第三次提交

abc@LAPTOP-5T03DV1G MINGW64 /f/develop/IdeaProjects/temp/git-study (v1.0)$ git add .xxx$ git commit -m "第三次提交"xxx$ git pushxxx
d50d482d858ccaeb51a3264fd8f8f19a.png

4、准备向 master 主干合并这个 v1.0,先切换到 master git checkout master

abc@LAPTOP-5T03DV1G MINGW64 /f/develop/IdeaProjects/temp/git-study (v1.0)$ git checkout master

5、将 v1.0 并入 master,注意,现在已经是在 master下操作了哦

abc@LAPTOP-5T03DV1G MINGW64 /f/develop/IdeaProjects/temp/git-study (master)$ git merge v1.0

6、Push 上去,origin master 不写也行,默认就是 master

abc@LAPTOP-5T03DV1G MINGW64 /f/develop/IdeaProjects/temp/git-study (master)$ git push origin master

你就会发现,master 主干下已经并入了 v1.0 的内容

86a3213ea8fd89cdaac109208e9b2deb.png

说明:提交信息,出现一个小乱码,是编码没设置好,没设置的情况下,还是推荐使用英文提示信息,修改后再根据需要选择是否提交中文信息

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/502453.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

stotybord如何添加子视图_SQL复杂查询-子查询

视图:1.视图的概念引入:SQL数据库里面存放的是SQL语句,视图中查看到的SQL查询语句,当我们运用客户端连接到视图时候,视图会运行里面的查询语句,从库中查找出数据,保存在临时表里面。当客户端和数…

springboot 2.3_Spring Boot 应用监控,早发现早

小Hub领读:服务都需要监控,SpringBoot项目中,你常用哪些监控模块呢?actuator?admin?作者:小小____https://segmentfault.com/a/1190000022945443当一个 Spring Boot 应用运行的时候,开发者需要对 Spring …

sql statements_Postgresql监控sql模块之pg_stat_statements模块--部署篇

概述今天主要介绍一下PG一个很重要的模块--pg_stat_statements模块,对于做性能观察还是很不错的。一、pg_state_statements模块简介1、简介pg_stat_statements模块提供一种方法追踪一个服务器所执行的所有 SQL 语句的执行统计信息,可以用于统计数据库的资…

linux服务配置大全 fedora 8 ftp 百度文库,Linux下VSFTP配置全攻略

Linux下VSFTP配置全攻略[日期:2007-10-05]来源:Linux公社作者:Linuxidc[字体:大 中 小]4]如果要以系统中存在的普通用户登入FTP,也没有什么可以设置的,添加一个用户就行。比如我要添加beinan这个用户&#…

sqlserver 还原bak文件 查看不到_SQL server中用T-SQL语句实现(建库,分离,附加,备份,还原)...

会用图形界面创建后,今天可以学习用T-SQL来创建数据库及对数据库的操作。一. T-SQL 创建数据库--创建数据库create database MySchool--创建数据库 数据库名称MySchoolon primary(--创建主数据库文件nameMySchool_data,--主数据库文件名称fileNameD:MySchool_data.m…

win7变成linux桌面背景,教大家把Ubuntu界面改造成Windows7系统

经常使用windows7系统的用户可能比较喜欢windows7系统强大的系统界面,下面就教大家如何使Ubuntu看起来像Windows 7系统的界面,具体内容如下所述,Ubuntu自身拥有相当不错的主题系统、视觉效果和养眼的画面,但你可能喜欢windows7的A…

怎么通过MQTT查看数据是否上云端_设备工程师们的福利来啦!JSON数据采集网关帮你实现云端对接~...

JSON数据采集网关是一种能够将各种传感器的数据采集后按照JSON格式上传服务器的网关。图 JSON数据采集网关工作原理示意图JSON(JavaScript Object Notation)是java中的数据格式。例如{“power”:”100”, “time”:”10:12:23”}这样的格式,由于它简单易用&#xff…

oracle 会话数上不去_Oracle初识

1、基本概念oracle数据库是一个物理概念,oracle实例是数据库在内存中的镜像,属于一种逻辑概念。oracle数据库与oracle实例至少是一对一的关系,也可能是一对多关系(oracle集群:RAC real application cluster&#xff09…

trace Linux and实例,traceroute在linux中的使用方法

traceroute在linux中的使用方法一、traceroute的实现原理1、IP协议利用存活时间TTL来发出探测包跟踪数据包到达目标ip主机所经历的路由网关数量,每经过一个路由器,TTL的值就减去1。当TTL值为0时,主机就取消发送数据包,并回传一份I…

在VS中怎么用vb画矩形_(十四)矩形和操作展示逻辑操作

时间为友,记录点滴。聊了这么多的图片运算,忽然有个想法,为什么非要用静态的图片来展示运算呢?我们可以用自己做的图片来经过运算后显示出来。说干就干。先想一下需求:整体环境非黑即白。可以用鼠标在背景上画出矩形&a…

c++ 二维数组 排序_漫画:“排序算法” 大总结

​冒泡排序:漫画:什么是冒泡排序?​mp.weixin.qq.com选择排序:漫画:什么是选择排序?​mp.weixin.qq.com插入排序:漫画:什么是插入排序?​mp.weixin.qq.com此外还有冒泡排…

ieee39节点系统介绍_Java秒杀系统实战系列-基于ZooKeeper的分布式锁优化秒杀逻辑...

本文是“Java秒杀系统实战系列文章”的第十六篇,本文我们将继续秒杀系统的优化之路,采用统一协调调度中心中间件ZooKeeper控制秒杀系统中高并发多线程对于共享资源~代码块的并发访问所出现的并发安全问题,即用ZooKeeper实现一种分布式锁&…

centos配置c语言环境变量,CentOS7设置环境变量

一、环境变量的概念1、环境变量的含义程序(操作系统命令和应用程序)的执行都需要运行环境,这个环境是由多个环境变量组成的。2、环境变量的分类1)按生效的范围分类。系统环境变量:公共的,对全部的用户都生效。用户环境变量:用户私…

python 3.7.732位安装步骤_Python3.7安装pyaudio教程解析

本人笔记本电脑安装的是 python3.7, 64位操作系统,基于x64的处理器 因为 pyaudio 暂时不支持 python3.7 和 3.8,所以若需要安装 pyaudio 需要下载 whl 文件后再离线进行安装。 首先:下载安装 pyaudio 的 whl 文件 然后按下 ctrlf 输入关键字&…

python open写入_Python3 open() 函数详解 读取文件写入文件追加文件二进制文件

Python3 open() 函数详解 读取文件写入文件追加文件二进制文件 open()函数的主要作用是打开文件并返回相应文件对象,使用文件对象可以对当前文件进行读取、写入、追加等操作,默认情况下"r"模式,文件不存在的话会发生OSError错误的。…

一部分 数据 迁移_从虚机到容器,知名架构师告诉你如何平滑进行业务迁移

【小宅按】近期,短视频产品“秒拍”完成了一个“大动作”——将原来部署在虚拟机上的主体业务迁移到华为云,同时将公司的技术体系承载在下一代虚拟技术容器(Docker)上。而这一系列动作是在业务不下线,用户无感知的前提…

cuda 实现sift gpu_为Keras提供GPU加速

在刚入坑机器学习时,书上所使用的算法(回归、决策树等)及实例较为简单,一般CPU(中央处理器)的计算能力均能胜任,从而快速实现。但若使用keras(一种基于深度学习框架的高级应用接口&a…

此 sqltransaction 已完成;它再也无法使用_win10笔记本自带office报错无法激活的解决方法...

激活win10笔记本电脑自带office出错怎么办?不少笔记本电脑在出厂的时候就自带windows 10操作系统并且将系统部署完成后就有许多软件集成当中,一般按正常步骤进行激活即可正常使用,不过有用户遇到一个问题,在激活自带office时报错了&#xff…

bat 连续读取两行_Redis底层数据结构解析(BAT大厂必问)

Redis是一个key-value存储系统,现在在各种系统中的使用越来越多,大部分情况下是因为其高性能的特性,被当做缓存使用。Redis由于其丰富的数据结构也可以被应用到其他场景。Redis是一个K-V的非关系型数据库(NoSQL)&#…

smart原则_为什么现在少有人用德鲁克的SMART原则做目标管理了?

互联网平台充斥了各类成功学文章,但大多数鸡汤文只谈坚持,不谈策略。王健林定下一个亿的小目标被网友编成了各种段子,却极少有人去探究他实现目标的过程,用的什么方法。从企业规模来看,我们没有理由说王健林定下的目标…