代码怀孕了,谁是父亲?(代码孕多久能合法化)
haoteby 2025-05-02 10:30 66 浏览
来人人都是产品经理【起点学院】,BAT实战派产品总监手把手系统带你学产品、学运营。
很多产品经理可能一直以来有这样一个疑问,这么多程序猿是怎么在一起撸代码的啊?
- 方法一:每个人都只写一个独立的模块,坚决不和其他程序猿有交集。(当然,这是活在梦里的想法)
- 方法二:一个程序猿改某个代码文件的时候其他也需要改动这个文件的程序猿先一边凉快去,等改完了再上。(听起来有点对代码进行排队轮x的意思啊...)
- 方法三:每个程序猿都按照自己的节奏改代码,最后把修改合到一起。
听起来,第三种方法比较靠谱,可是我们还需要依靠一个强大的文件版本管理工具才可以实现哦,这个就是svn。在开始协同撸代码前,需要在一个公共的主机上搭建svn的服务器,然后如同大厦奠基般需要创建一个svn的目录,自此,所有程序猿写的代码都需要提交到这个svn的目录上面,同时,所有程序员的代码修改都要以svn服务器上的代码为基准。
程序猿在svn上撸代码时有三个重要操作:更新,编辑冲突,提交。首先程序猿将服务器上的最新代码更新到本地,然后以此代码为基准在本地开始进行自己的修改,当自己修改的比较满意后,会想要将这些本地的修改提交到服务器上,但是由于修改的这段时间,别的程序猿也可能提交了一些代码,所以需要再次更新一下,看看这段时间别人修改的代码和自己修改的部分有没有冲突,这里svn提供了差异比对的功能,如果有相同部分的代码被修改了,svn就会在更新的时候给出提示,需要程序猿对这些代码修改冲突的地方进行检查并再次修改保证没有冲突后,才可以提交代码。(代码提交高峰期可能出现一提交就冲突,刚修改完冲突,一提交又冲突,这个才郁闷啊)
有的程序猿比较懒,会跳过更新,编辑冲突,直接进行提交,如果运气好,提交的文件在这段时间别人都没有修改过,那么就没有冲突,可以提交成功。但是如果提交的时候svn进行比对发现有文件被别人修改过了,这个时候会强制提醒程序猿走一次更新,编辑冲突的流程。一旦提交成功,svn服务器便会详细记录此次提交,并递增的分配一个版本号。
这里看到,svn有两个重要的功能,文件提交记录和文件修改比对。
程序猿们在协同编码的时候也会发生一些有趣的事情。一个人写代码会有bug,几个人同时写代码那就更容易出bug了,这样就会产生bug纠纷,就好比程序代码被轮x了,怀孕了,现在要找父亲了,可父亲是谁呢?被列为嫌疑犯的程序猿肯定都不希望孩子是自己的,不免会互相争论一番。传统解决方法就是慢慢调试,找到产生bug的相关代码,然后让写bug的程序猿去修复。但是让谁去调试bug呢,毕竟耗时又耗力?有人愿意担当还好,如果都觉得bug不是自己的不愿意去查bug,就又会陷入僵持了。这个时候svn就派上用场了:进行代码回退。svn服务器因为详细记录了每次提交,所以它可以完整的回退到任意一个版本上,那么就可以不断向前回退提交,然后运行程序,就可以找到究竟是哪次提交产生了这个bug,从而确认是哪个程序猿搞出来的bug。
同时根据这个理论,产生了bug追责究极大法-svn二分法,据说被此法追责到的程序猿能绕地球一圈。怎么操作呢?例如回退到版本号100上没有这个bug,回退到版本号200上有这个bug,那么就回退到版本号150上看看有没有这个bug,如果有就继续查版本号125,没有就查版本号175,以此类推,不断缩小追查区间,最终一定能确定到某一个版本号对应提交产生了这个bug,只要看看这个版本是谁提交的可以知道是谁的bug了。(当然svn的功能可不仅仅是这些哦,有兴趣的可以详细把玩一下)
古代妃子侍寝的时候都会有太监记录,这样日后怀孕了也可以推断出是不是皇帝的。
历史总是惊人的相似...
#专栏作家#
给产品经理讲技术,微信公众号(pm_teacher),人人都是产品经理专栏作家。资深程序猿,专注客户端开发若干年,对前端、后台技术略懂,热衷于对新的科技领域的探索。
相关推荐
- 如何为MySQL服务器和客户机启用SSL?
-
用户想要与MySQL服务器建立一条安全连接时,常常依赖VPN隧道或SSH隧道。不过,获得MySQL连接的另一个办法是,启用MySQL服务器上的SSL封装器(SSLwrapper)。这每一种方法各有其...
- k8s 证书问题排查_k8s dashboard 证书
-
从去年开始一些老项目上陆陆续续出现一些列的证书问题,(证书原理这里就不说了,官方文档一堆)多数刚开始的表现就是节点的kubelet服务起不来,节点状态NotReady表现日志如下failed...
- 企业级网络互通方案:云端OpenVPN+爱快路由器+Win11互联实战
-
企业级网络互通方案:OpenVPN搭建公有云+爱快路由器+Win11三地互联实战指南「安全高效」三地局域网秒变局域网实施环境说明...
- OpenV** Server/Client配置文件详解
-
Server配置详解...
- 接口基础认知:关键信息与合规前提
-
1.核心技术参数(必记)...
- S交换机通过SSH登录设备配置示例(RADIUS认证+本地认证独立)
-
说明:●本示例只介绍设备的认证相关配置,请同时确保已在RADIUS服务器上做了相关配置,如设备地址、共享密钥、创建用户等配置。●通过不同的管理域来实现RADIUS认证与本地认证两种方式同时使用,两...
- SSL证书如何去除私钥密码保护_ssl证书怎么取消
-
有时候我们在生成证书的时候可以加入了密码保护。然后申请到证书安装到了web服务器。但是这样可能会带来麻烦。每次重启apache或者nginx的时候,都需要输入密码。那么SSL证书如何去除私钥密码保护。...
- SSL证书基础知识与自签名证书生成指南
-
一、证书文件类型解析...
- S交换机通过SSH登录设备配置示例(RADIUS认证)
-
说明:本示例只介绍设备的认证相关配置,请同时确保已在RADIUS服务器上做了相关配置,如设备地址、共享密钥、创建用户等配置。假设已在RADIUS服务器上创建了用户名yc123,密码test#123。对...
- HTTPS是什么?加密原理和证书。SSL/TLS握手过程
-
秘钥的产生过程非对称加密...
- HTTPS TLS握手流程_进行tls握手
-
1.客户端向服务器发送`ClientHello`消息,包括支持的TLS版本、加密套件、随机数等信息。2.服务器收到`ClientHello`消息后,解析其中的信息,并根据配置选择一个加密套件。3....
- Spring Boot 单点登录(SSO)实现_spring boot 单点登录jwt
-
SpringBoot单点登录(SSO)实现全指南单点登录(SingleSign-On,SSO)是一种身份验证机制,允许用户使用一组凭证登录多个相关但独立的系统。在微服务架构和企业级系统中,SS...
- 源码分享:在pdf上加盖电子签章_pdf如何加盖电子公章
-
在pdf上加盖电子签章,并不是只是加个印章图片,。而是要使用一对密钥中的私钥对文件进行签字。为啥要用私钥呢?很简单,因为公钥是公开的,其他人才可以用公钥为你证明,这个文件是你签的。这就是我们常说的:私...
- 微信支付商户API证书到期 怎么更换
-
微信支付商户API证书到期更换是一个非常重要的操作,需要仔细按照流程进行。如果证书过期,所有通过API的支付、退款等操作都会失败,将直接影响您的业务。请按照以下详细步骤进行操作:重要前提:分清...