我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Git在项目协作开发中所解决问题

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Git在项目协作开发中所解决问题

1、Git的历史

Git是目前世界上最先进的分布式版本控制系统,开源、免费。

Git 是 Linus (林纳斯)为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

Tips:

Linus在1991年创建Linux,现在已经成为最大的服务器系统软件了。

Linux的壮大是靠全世界热心的志愿者:

在2002年以前,世界各地的志愿者把源代码文件发给Linus,然后由Linus本人通过手工方式合并代码!

为什么Linus不把Linux代码放到版本控制系统里呢?

不是有CVS、SVN这些免费的版本控制系统吗?

因为Linus坚定地反对CVS和SVN,这些集中式的版本控制系统不但速度慢,而且必须联网才能使用。

有一些商用的版本控制系统,虽然比CVS、SVN好用,但那是付费的,和Linux的开源精神不符。

不过,到了2002年,Linux系统已经发展了十年了,代码库之大让Linus很难继续通过手工方式管理了,社区的里也对这种方式表达了强烈不满,于是Linus选择了一个商业的版本控制系统BitKeeper,BitKeeper的东家BitMover公司出于人道主义精神,授权Linux社区免费使用这个版本控制系统。

安定团结的大好局面在2005年就被打破了,原因是Linux社区牛人聚集,开发Samba的这个人Andrew,试图破解BitKeeper的协议(这么干的其实也不只他一个),被BitMover公司发现了,于是BitMover公司怒了,要收回Linux社区的免费使用权。

Linus花了两周时间自己用C写了一个分布式版本控制系统,这就是Git!一个月之内,Linux系统的源码已经由Git管理了!

Linus 对新的版本控制系统制订了若干目标,如下图所示:

Git迅速成为最流行的分布式版本控制系统,尤其是2008年,GitHub网站上线了,它为开源项目免费提供Git存储,无数开源项目开始迁移至GitHub,包括jQuery,PHP,Ruby等等。

历史就是这么偶然,如果不是当年BitMover公司威胁Linux社区,可能现在我们就没有免费而超级好用的Git了。

Git的发展历史图:

2、Git的特点

当Git刚刚推出的时候很多人还对他发生质疑,但是不久之后因为Git具备非常好的特点,导致了开源社区很多项目没过多久,就陆陆续续的从SVN上转移到Git上来进行版本控制。

(1)Git的特点如下:

  • Git中每个克隆(clone)的版本库都是平等的。你可以从任何一个版本库的克隆来创建属于你自己的版本库,同时你的版本库也可以作为源提供给他人,只要你愿意。
  • Git的每一次拉取操作,实际上都是一次对代码仓库的完整备份。
  • 提交完全在本地完成,无须别人给你授权,你的版本库你作主,并且提交总是会成功。
  • 甚至基于旧版本的改动也可以成功提交,提交会基于旧的版本创建一个新的分支。
  • Git的提交不会被打断,直到你的工作完全满意了,PUSH给他人或者他人PULL你的版本库,合并会发生在PULL和PUSH过程中,不能自动解决的冲突会提示您手工完成。
  • 冲突解决不再像是SVN一样的提交竞赛,而是在需要的时候才进行合并和冲突解决。
  • Git版本库统一放在服务器中。Git 也可以模拟集中式的工作模式,同时Git 的集中式工作模式非常灵活,
  • 团队的成员先将服务器的版本库克隆到本地;并经常的从服务器的版本库拉(PULL)最新的更新。
  • 团队的成员将自己的改动推(PUSH)到服务器的版本库中,当其他人和版本库同步(PULL)时,会自动获取改变。
  • 你完全可以在脱离Git服务器所在网络的情况下,如移动办公/出差时,照常使用代码库。
  • 你只需要在能够接入Git服务器所在网络时,PULL和PUSH即可完成和服务器同步以及提交。
  • Git提供 rebase 命令,可以让你的改动看起来是基于最新的代码实现的改动。
  • Git 有更多的工作模式可以选择,远非 Subversion可比。
  • 协同修改,多人可并行修改服务器端的同一个文件。
  • 数据备份,不仅保存目录和文件的当前状态,还能够保存每一个提交过的历史状态。
  • 版本管理,在保存每一个版本的文件信息的时候要做到不保存重复数据,以节约存储空间,提高运行效率。这方面SVN采用的是增量式管理的方式,而Git采取了文件系统快照的方式(对比Hash值)。
  • 权限控制,对团队中参与开发的人员进行权限控制。谁能创建版本库,谁能向版本库PUSH,谁能够读取(克隆)版本库。对团队外开发者贡献的代码进行审核,通过fork。(Git独有)。
  • 历史记录,查看修改人、修改时间、修改内容、日志信息。将本地文件恢复到某一个历史状态。
  • 分支管理,允许开发团队在工作过程中多条生产线同时推进任务,进一步提高效率。

(2)简单说明:

Git有最优的存储能力以及非凡的性能,得益于林纳斯(Linus Torvalds:林纳斯·本纳第克特·托瓦兹,Linux内核的发明人)本身的这个技能,他是Linux内核专家,也是文件系统的管理专家。所以他开发出来的Git具备了最优的存储能力以及非凡的性能。林纳斯它本身就是崇尚开源的,所以他开发的Git也是开源的。

Git还很容易做备份,还支持离线的操作。基于Git的分支管理的成本是非常低的,而且也非常容易定制工作流程。

在实际使用分布式版本控制系统的时候,其实很少在两人之间的电脑上推送版本库的修改,因为可能你们俩不在一个局域网内,两台电脑互相访问不了,也可能今天你的同事病了,他的电脑压根没有开机。因此分布式版本控制系统通常也有一台充当”中央服务器”的电脑,但这个服务器的作用仅仅是用来方便“交换”大家的修改,没有它大家也一样干活,只是交换修改不方便而已。

3、Git在项目协作开发中所解决的问题

  • 多人协作,出现代码冲突 (版本控制工具)
  • 多人协作,在代码整合期间引发BUG(回滚)
  • 多人协作,领导要看项目 (版本历史)
  • 多人协作,用户身份的控制(权限管理)
  • 项目版本的发布问题 (标志&里程碑管理)

参考: https://www.jb51.net/article/245619.htm

以上就是Git在项目协作开发中所解决问题的详细内容,更多关于Git项目协作开发的资料请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Git在项目协作开发中所解决问题

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Vue开发项目中的兼容问题怎么解决

今天小编给大家分享一下Vue开发项目中的兼容问题怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1. KingEdit
2023-07-04

Go语言项目开发中的常见问题与解决方案

Go语言项目开发中的常见问题与解决方案Go语言作为一种简洁高效的开发语言,受到越来越多的开发者的青睐。在实际的项目开发中,开发者也会遇到一些常见的问题。本文将提供一些常见问题的解决方案,帮助开发者更好地应对挑战。一、依赖管理在Go语言项目中
Go语言项目开发中的常见问题与解决方案
2023-11-04

Go语言项目开发的常见问题与解决方法

Go语言作为一种高性能、简洁易用的编程语言,越来越多的开发者开始选择它作为项目开发的首选语言。然而,在实际的项目开发过程中,我们也会遇到一些常见的问题。本文将介绍一些这样的问题,并提供相应的解决方法,帮助开发者更好地应对这些挑战。问题一:依
Go语言项目开发的常见问题与解决方法
2023-11-03

PHP Git 实战:如何解决代码管理与协作中多人协作可能导致的问题?

答案:git 协作中常见的两个问题是代码冲突和不兼容的更改。代码冲突:当多人同时修改同一个文件时,会产生代码冲突,需要手动编辑文件解决冲突。不兼容的更改:当协作者做出不兼容的更改时,例如修改数据库架构和代码逻辑,需要手动调整代码确保兼容。P
PHP Git 实战:如何解决代码管理与协作中多人协作可能导致的问题?
2024-05-14

Vue项目中使用setTimeout存在的潜在问题及解决

这篇文章主要介绍了Vue项目中使用setTimeout存在的潜在问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-01-28

CSS开发心得:解决常见问题的项目经验总结

CSS(层叠样式表)作为前端开发中不可或缺的一部分,负责页面的样式设计与布局。在项目开发过程中,我们常常会碰到一些常见的CSS问题,解决这些问题是提高项目开发效率和质量的重要环节。本文将总结一些解决常见CSS问题的项目经验,希望能为开发者们
CSS开发心得:解决常见问题的项目经验总结
2023-11-03

PHP Git 实战:如何解决代码管理与协作中的常见问题?

摘要:使用 git 管理 php 代码时,常见问题及其解决方法包括:跟踪代码更改:git add提交更改:git commit拉取远程仓库更改:git pull管理代码冲突:git merge解决拉取请求冲突:git fetch、git m
PHP Git 实战:如何解决代码管理与协作中的常见问题?
2024-05-13

在python项目中使用2sys.argv时遇到的问题如何解决

这篇文章主要介绍了在python项目中使用2sys.argv时遇到的问题如何解决,此处通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考价值,需要的朋友可以参考下:python可以做什么Python是一种编程语言,内置了许多
2023-06-06

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录