·1.1 git的概述

  Git(读音为/gɪt/。)是一个开源的分布式版本控制系统,可以有效、高速的处理从很小到非常大的项目版本管理。  Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

1.2 git的服务器地址

  • 国内git服务器地址:https://gitee.com/
  • 国外git服务器地址:https://github.com/
  • 准备码云gitee账号,我的是gww.vip@qq.com和gww.dev@qq.com

1.3 Git原理图

原理:我在idea写代码,idea就是工作区,提交到远程仓库前,先要提交到本地仓库。在本地仓库这边有两步,第一步先把代码add到本地仓库的暂存区(storage),第二步再commit到本地仓库主分支(也就是master),最后才可以把本地仓库的代码提交远程仓库里,总共就这么三步,当然实际工作中,我们在准备push的时候要先拉取一下代码,看与自己代码有没有冲突的地方(两个人在同一方法里写了不同代码),有的要和对方协商修改合并,最后再提交。

        

2 实战

  • 这里使用IDEA内置的git功能来讲解使用
  • 在学习前先安装 git管理工具到本地
  • git工具默认安装的路径如下图,安装完后把bin目录添加path变量中,在终端可以查看git工具的版本号

        

              

2.1 工作时开发的注意事项

  • 代码需要备份【主要是防止代码丢失】
  • 每个大版本都需要备份分支持【主要是1.0出现问题时,不能在2.0的版本上修复】
  • 每天上午上班,要从服务器下载最新的代码到本地
  • 每天下午下班前,把自己的代码提交到服务器
  • 团队开发时需要解决文件冲突问题

2.2 commit,push,branches,master讲解

*****掌握每一个使用步骤的原理

Step1——配置idea

  

Step2——在码云上创建空白的Java仓库,用于存储工作中开发的代码备份

step3——上传本地空项目到码云上,让仓库拥有一个项目结构

先在idea中创建一个新的javaweb项目

先随便在里面建个包,写个java文件

在码云上创建的仓库名例如mayaole/gyfdemo01点一下,看到文件那点一下,点上传文件,可以找到本地项目里的文件拖到网页位置,这个初始的项目就上传到远程仓库了

 step4——在IDEA中从码云下载项目,下载的地址就是在git中克隆的位置

找到VCS,选择git,表示从服务器下载代码

然后把git的仓库地址复制,如图,然后点clone复制份到本机桌面的某个文件夹下

之前在本地建的新项目就不再用了,可以先删掉

克隆后,文件夹里打开如下

新创建一个文件时,把有下面的弹窗口,选择Yes, 它意思是如果不小心选中了No,仍然可以通过另一种方式添加到本地仓库缓存,如下,第二张是我说的另一种方式

Step6——commit提交代码并写上备注这里是从暂存区存到本地仓库主干

Step7——把代码提交(push)到服务器

在推的过程中,会弹出输入git服务器的用户名和密码,输入即可

推送成功后,在码云服务器会看到更新的功能

Step9————写点功能,如UserService,然后提交发布V1.0.0,然后添加分支

选择创建分支

Step10——切换回主干

current表示本地当前项目所在分支,新版本事一个书签的标志

Step11——在主杆上进行2.0的开发,添加邮件发送功能

Step12——切换回1.0分枝,进行Bug修复,然后提交(这是为了说明两个分支可以分开也业务,互不冲突)

Step13——推1.0代码到服务器

Step14——不要忘记把主杆也推上服务器,先切换回主杆,再push

Step15——将主分支master与1.0合并分支(合并完后,当前项目还是master主分支,只不过变成合并完的master主分支)

合并后,就把master推上服务器

用当前mater创建2.0分枝,那么master就是3.0分枝了,然后把2.0推到服务器

2.3提交历史记录查看

2.4对比不同版本的区别

 

 

2.5回退到上一个版本

  • 比如你误删了一段代码(方法),但又提交了,可以使用下面的get来进行回退
 

2.6 团队开发,解决冲突

Step1——准备两个马云账号

不,说错了,是码云账号,为什么两,为了模拟两个开发者,然后电脑里再准备一台虚拟机,上面也装idea,码云远程项目里面添加邀请第二个账号后,第二个同意完后也把项目chone进idea开发,写同一个业务位置,制造不同

Step2——添加其它开发者到当前项目组

Step3:

  • 在虚拟机中给某个类添加一些代码,比如添加个方法,然后push到服务器
  • 在push服务器中,可能失败,因为你没有把另一个开发者的帐号添加到项目组中
 

 

Step4:

  • 在本机中也在同一个文件中修改或者添加代码
  • 然后push到服务器会失败,因为代码冲突了
 

 

合并前

 

合并后,然后再次push即可以了

注意:A开发者更新后,另一个开发者可以重新pull更新代码到本地

 

教程会有不足,还请看的指出,后面还会修改,内容会有一定时效性,随着时间推移,会有新的功能样式出现,或更简单的操作界面。程序员就是不停的学。

git工作中最常用的用法教程,不走命令行的更多相关文章

  1. git工作中的常用操作

    上班开始,打开电脑,git pull:拉取git上最新的代码: 编辑代码,准备提交时,git stash:将自己编辑的代码暂存起来,防止git pull时与库中的代码起冲突,否则自己的代码就白敲了: ...

  2. Git工作中的使用

    Git工作中的使用 2019-01-16 14:29:31 雯雯木 阅读数 207更多 分类专栏: 自动化测试   版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出 ...

  3. C++中string常用函数用法总结

    string(s小写)是C++标准库中的类,纯C中没有,使用时需要包含头文件#include<string>,注意不是<string.h>,下面记录一下string中比较常用的 ...

  4. gplaycli—— 用于从 GooglePlayStore 中下载和管理 Apk 文件的命令行工具

    gplaycli-- 用于从 GooglePlayStore 中下载和管理 Apk 文件的命令行工具 这个 GooglePlay市场 中 https://play.google.com/store/a ...

  5. git 工作中常用命令(结合vscode学习git 命令)

    作为一名前端开发,大家在工作中常常使用什么开发工具呢,我觉得我首选的是vscode,他配合git使用起来非常方便. 工作中常用三个命令: git终端常使用: git add . git commit ...

  6. git工作中常用操作总结

    这篇文章主要记录下工作中常用的git操作.主要是对之前文章记录的问题做个总结,这个其实在idea中操作更加简单 别名配置 在敲git 命令时,其实可以使用别名,比如 commit可以配置为ci 下面是 ...

  7. git工作中常用命令-工作中踩过的坑

    踩坑篇又来啦,这是我在工作中从git小白进化到现在工作中运用自如的过程中,踩过的坑,以及解决办法. 1.基于远程develop分支,建一个本地task分支,并切换到该task分支 git checko ...

  8. Git 工作原理以及常用命令操作

    GIT工作原理 要了解GIT工作原理,先了解GIT的这几块区域: 工作区域划分 工作区:指的是本地工作空间,如果刚拉取下来的代码,没有修改的内容,这块区域是空白的 (modified-已修改状态) 暂 ...

  9. git详情、git工作流程、常用命令、忽略文件、分支操作、gitee远程仓库使用

    今日内容概要 git详情 git工作流程 git常用命令 过滤文件 分支操作 git远程仓库使用 可参照:https://www.cnblogs.com/liuqingzheng/p/15328319 ...

随机推荐

  1. Java面试系列第3篇-HashMap相关面试题

    HashMap是非线程安全的,如果想要用线程安全的map,可使用同步的HashTable或通过Collections.synchronizeMap(hashMap)让HashMap变的同步,或者使用并 ...

  2. Linux下jdk的安装和环境变量的配置

    Linux下jdk的安装和环境变量的配置 一.jdk的下载 方式一:在官网下载 http://www.oracle.com/technetwork/java/javase/downloads/inde ...

  3. 使用sqlmap结合dnslog快速注入

    0x01 起因 实际项目中遇到一个oracle延时注入,需要获取数据,几十个库几百张表,等找到关键数据不知道要到哪天. 测试支持带外请求 于是想用使用sqlmap利用DNS进行OOB注入 0x02 阿 ...

  4. 9个小技巧让你的 if else看起来更优雅

    if else 是我们写代码时,使用频率最高的关键词之一,然而有时过多的 if else 会让我们感到脑壳疼,例如下面这个伪代码: 是不是很奔溃?虽然他是伪代码,并且看起来也很夸张,但在现实中,当我们 ...

  5. D3.js 力导向图的显示优化

    D3.js 作为一个前端,说到可视化除了听过 D3.js 的大名,常见的可视化库还有 ECharts.Chart.js,这两个库功能也很强大,但是有一个共同特点是封装层次高,留给开发者可设计和控制的部 ...

  6. Decision tree——决策树

    基本流程 决策树是通过分次判断样本属性来进行划分样本类别的机器学习模型.每个树的结点选择一个最优属性来进行样本的分流,最终将样本类别划分出来. 决策树的关键就是分流时最优属性$a$的选择.使用所谓信息 ...

  7. 单源最短路问题--朴素Dijkstra & 堆优化Dijkstra

    许久没有写博客,更新一下~ Dijkstra两种典型写法 1. 朴素Dijkstra     时间复杂度O(N^2)       适用:稠密图(点较少,分布密集) #include <cstdi ...

  8. eclipse 创建maven项目失败

    问题描述: eclipse 初次创建maven项目报错 可能是maven-archetype-quickstart:1.1.jar 包失效了或者没有? 有人说把这个jar包放在maven本地仓库里 我 ...

  9. mycat入门部署安装

    mycat是一种比较简单的中间件产品,可以帮助mysql进行分库,同时统一在一个逻辑库. 硬件环境:系统:centos 7.6数据库版本:5.7.19mycat:1.6..6.1 github上下载m ...

  10. swift 3.0字符串的简单使用

    let str:String = "12314124" 获取某个指定位置的元素 print(str.characters[str.index(str.startIndex, off ...