如何多人协同开发同一个项目?

使用代码版本控制[version control]软件,

目前市面上比较流行的代码版本控制器有: git,svn,csv

1. 使用git管理代码版本

本项目使用git管理项目代码,代码库放在gitee码云平台。(注意,公司中通常放在gitlab私有服务器中)

1.1 Git 的诞生

2005 年 4 月3 日,Git 是目前世界上最先进的分布式版本控制系统(没有之一)

作用:源代码管理

为什么要进行源代码管理?

  • 方便多人协同开发[防止代码冲突,相互覆盖]
  • 方便版本控制[利于以后的开发人员快速了解项目的开发过程,利于需求变更的时候进行代码回滚]

1.2 git与svn区别

SVN 都是集中控制管理的,也就是有一个中央服务器,大家都把代码提交到中央服务器,而

git 是分布式的版本控制工具,也就是说没有中央服务器,每个节点的地位平等。

SVN

Git

Git的windows下安装

官网地址:

https://git-scm.com/download

下载到本地磁盘

安装

一路【next】就可以了

注意:openssl 一定选它

安装完成后,右击菜单栏,有如下菜单,表示安装完成

进入git bash选项

Git工作区、暂存区和版本库

1、工作区介绍

就是在你本要电脑磁盘上能看到的目录。

2、暂存区介绍

一般存放在【.git】目录下的index文件(.git/index) 中,所以我们把暂存区有时也叫作索引。

3、版本库介绍

工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。git中的head/master是分支,是版本库。

git项目仓库的本地搭建

  1. cd进入到自己希望存储代码的目录路径,并创建本地仓库.git
  2. 新创建的本地仓库.git是个空仓库
  3. cd 目录路径
  4. git init gitdemo # 如果没有声明目录,则自动把当前目录作为git仓库

创建仓库

仓库目录的结构

  1. branches/ 分支管理目录
  2. config 当前项目仓木的配置信息
  3. description 当前项目的描述
  4. HEAD 当前项目仓库的当前版本信息
  5. hooks 当前项目仓库的钩子目录[可以利用这个目录下面的文件实现自己拉去代码到服务器]
  6. info 仓库相关信息
  7. objects 仓库版本信息
  8. refs 引用信息

配置用户名和邮箱

  1. git config --global user.name 'lisi'
  2. git config --global user.email 'lisi@163.com'

查看仓库状态

  1. git status
  2. git status s 简约显示
  • 红色表示新建文件或者新修改的文件,都在工作区.
  • 绿色表示文件在暂存区
  • 新建的login.py文件在工作区,需要添加到暂存区并提交到仓库区

上图表示: 暂时没有新文件需要提交到暂存区

添加文件到暂存区

  1. # 添加项目中所有文件
  2. git add .
  3. 或者
  4. # 添加指定文件
  5. git add login.py

例如: 创建3个文件 ,并查看状态.

提交到版本库

  1. git commit -am "版本描述"

手动删除文件

  1. 手动操作删除 或者 在命令行下 使用 rm 文件名 删除 都是表示在工作区删除.
  2. 对于这种删除,如果还原,则可以使用 git checkout 文件名

版本删除

  1. 如果使用 git rm 文件名, 这种操作属于暂存区删除,这种删除无法直接git checkout 文件名 来还原.
  2. 如果直接执行git checkout 命令,则报错如下:

  1. 如果要还原在暂存区中删除的文件,必须先执行 git reset head

查看历史版本[查看日志]

  1. git log 或者 git reflog
  2. 过滤查看日志
  3. git log p
  4. 退出按【q】键
  5. ctrl+f向下分页
  6. ctrl+b 向上分页
  7. 显示指定日期之后的日志 git log --after '2018-11-6'
  8. 显示指定日期之前的日志 git log --before '2018-11-6'
  9. 指定显示指定开发者的日志 git log --author 'lisi'

回退版本

  • 方案一:

    • HEAD表示当前最新版本

    • HEAD^表示当前最新版本的前一个版本

    • HEAD^^表示当前最新版本的前两个版本,以此类推...

    • HEAD~1表示当前最新版本的前一个版本

    • HEAD~10表示当前最新版本的前10个版本,以此类推...

      1. git reset --hard HEAD^

方案二:当版本非常多时可选择的方案

  • 通过每个版本的版本号回退到指定版本

    1. git reset --hard 版本号

取消暂存

  1. git reset head
  2. git reset <file> :从暂存区恢复到工作文件
  3. git reset -- :从暂存区恢复到工作文件

查看文件状态

针对与文件所处的不同分区,文件所处的状态:

(1)未追踪, 文件第一次出现在工作区, 版本库还没有存储该文件的状态

(2)已追踪, 只要第一次,git add了文件, 文件就是已追踪

(3)未修改, 文件在工作区未被编辑

(4)已修改, 文件在工作区被修改

(5)未暂存, 文件已修改, 但是没有add到暂存区

(6)已暂存, 已经将修改的文件add到暂存区

(7)未提交, 已暂存的文件, 没有commit提交. 处于暂存区

(8)已提交, 提交到版本库的文件修改,只有commit以后才会有仓库的版本号生成

注意:

  1. 公司一般使用git管理项目,往往会搭建一个gitlab自己内部管理代码,也有公司选择使用码云的企业版仓库来管理
  2. 使用git开发项目时,有时候不一定通过https协议提交代码的。也有的公司是通过ssh协议提交,此时需要生成ssh公钥和提交公钥给仓库。[码云这些官网都会有详细的提示说明]
  3. 生成SSH公钥【必须安装git bash才可以使用这个命令,而且还要把git bash添加到系统变量里面】
  4. ssh-keygen -t rsa -C "lisi@163.com"
  5. 参考:https://gitee.com/help/articles/4180

2. 在git平台创建工程

1) 创建私有项目库

创建私有空仓库以后的界面:

2)克隆项目到本地

  1. git clone 仓库地址
  2. 注意,如果当前目录下出现git仓库同名目录时,会克隆失败。

3)创建并切换分支到dev

  1. # git branch dev # 创建本地分支dev,dev是自定义
  2. # git checkout dev # 切换本地分支代码
  3. git checkout -b dev # 这里是上面两句代码的简写

git提交

  1. git add 代码目录
  2. git status
  3. git commit -m '添加项目代码'

推送到远端

  1. git push origin dev:dev

如果推送代码,出现以下提示: git pull ....,则表示当前本地的代码和线上的代码版本不同.

  1. 1. 把线上的代码执行以下命令,拉取到本地,进行同步
  2. git pull
  3. 2. 根据提示,移除多余的冲突的文件,也可以删除.
  4. 完成这些步骤以后,再次add,commit,push即可.

GIT篇章(二)的更多相关文章

  1. Git 笔记二-Git安装与初始配置

    git 笔记二-Git安装与初始配置 Git的安装 由于我日常生活和工作基本上都是在Windows上,因此此处只说windows上的安装.Windows上的安装和其他程序一样,只需要到http://g ...

  2. 版本控制git之二 分支 切换分支 创建分支 合并 删除

      版本控制git之二 分支   有人把 Git 的分支模型称为它的`‘必杀技特性’',也正因为这一特性,使得 Git 从众多版本控制系统中脱颖而出. 为何 Git 的分支模型如此出众呢? Git 处 ...

  3. Git(二)Git几个区的关系与Git和GitHub的关联

    前言 前面只是大概的介绍了一点基础的东西,接下来会更加深入的去了解一下Git. 一.Git的工作区.暂存区和版本库之间的区别和联系 1)工作区 在PC中能看得到的创建的一个管理仓库的目录.比如目录下G ...

  4. 【Git学习二】深入了解git checkout命令

    检出命令(git checkout)是Git最常用的命令之一,同时也是一个很危险的命令,因为这条命令会重写工作区.检出命令的用法如下: 用法一:git checkout[-q][<commit& ...

  5. Git(二)使用git管理文件版本(TortoiseGit )

    一.创建版本库 什么是版本库呢?版本库又名仓库,英文名repository,你可以简单理解成一个目录,这个目录里面的所有文件都可以被Git管理起来,每个文件的修改.删除,Git都能跟踪,以便任何时刻都 ...

  6. 【Git】二、安装配置

    一.Git安装 Linux $ apt-get install libcurl4-gnutls-dev libexpat1-dev gettext \ libz-dev libssl-dev $ ap ...

  7. git学习——<二>git配置文件

    一.git所有配置文件 <一>./etc/gitconfig全局配置文件 修改该配置文件,会对所有用户有影响. 使用git config --system来配置该文件 <二>. ...

  8. Git系列二之数据管理

    1.Git基本管理 git常用的基本操作 1.1提交数据 我们可以简单的把工作目录理解成是一个被Git服务程序管理的目录,Git会时刻的追踪目录内文件的改动,另外在安装好了Git服务程序后,默认就会创 ...

  9. 分布式版本号控制系统Git(二):github

    前言 但凡是喜欢研究技术,或者听大牛们说起过的,都应该至少是听过github这个东西.详细就不介绍了.不了解的能够去了解了解,最基本的功能当然是代码托管啦,上面有各种各样的大牛写的项目. 另外这一章不 ...

随机推荐

  1. openstack Train 版本dashaboard 404问题

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明本文链接:https://blog.csdn.net/weixin_28738845/articl ...

  2. 解决Error: ENOENT: no such file or directory, scandir 'xxx\node-sass\vendor'

      解决方案是执行以下方法: npm rebuild node-sass

  3. oracle查看被锁的表及解除锁

    -- 查看被锁对象 select object_name,machine,s.sid,s.serial# from v$locked_object l,dba_objects o ,v$session ...

  4. Django之创建项目、目录层级、基本操作

    创建项目 在合适的位置创建一个目录 打开cmd窗口,进入到创建的目录内 输入django-admin startproject project 目录层级 manage.py 是一个命令行工具,可以使我 ...

  5. VIJOS-P1474 雷曼兔(csapc)

    JDOJ 1532: VIJOS-P1474 雷曼兔(csapc) https://neooj.com/oldoj/problem.php?id=1532 Description 这次,OI山成为了雷 ...

  6. Redis笔记1-Redis介绍及数据类型使用场景

    Redis介绍:C语言开发.单线程操作.高性能.键值对.可持久化的数据库.Redis采用redisObject结构来统一五种数据类型,redisObject是五种类型的父类,可以在函数间传递时隐藏具体 ...

  7. Umi + Dva的数据传递学习Demo(代码有详细注释)

    刚学习时写了篇笔记,以免自己忘记,用了一段时间后,觉得不如做个demo,代码写上注释,方便也在学习umi-dva的同学们理解更好,更容易上手. 这可能是网上注释最多,看了最易理解的学习小指南吧,哈哈. ...

  8. find square root

    public class Solution { public static void main(String[] args) { Scanner ip = new Scanner(System.in) ...

  9. Scala词法文法解析器 (二)分析C++类的声明

    最近一直在学习Scala语言,偶然发现其Parser模块功能强大,乃为BNF而设计.啥是BNF,读大学的时候在课本上见过,那时候只觉得这个东西太深奥.没想到所有的计算机语言都是基于BNF而定义的一套规 ...

  10. Beta冲刺(5/7)——2019.5.27

    作业描述 课程 软件工程1916|W(福州大学) 团队名称 修!咻咻! 作业要求 项目Beta冲刺(团队) 团队目标 切实可行的计算机协会维修预约平台 开发工具 Eclipse 团队信息 队员学号 队 ...