作为一名软件开发,您是否认同“如果代码有效,就不要修复它”这一理论?

请大家关注我的公众号,“老胡聊Java”

这句话非常有道理,因为这句话不仅包含了技术,而且还包含了人情世故。

1 一个项目的代码动辄几千几万行,而且分布的位置也不同,比如有java代码python代码,甚至还可能有数据库SQL代码,你修改了其中一段,谁也不知道其它哪些地方调用了它。

而且哪怕你全局搜索了项目,也未必能确保其它项目,比如其它子模块或数据库SQL语句,一定没有调用它,所以你修改了,真可能会引发问题。

2 当下的代码大概率是经过多轮测试,即跑到现在是正常的。但如果你修改了不出问题还好,如果出了问题,别人一定第一时间会认为是你的责任,项目经理第一应对的措施,不是说让排查问题,而大概率是让你改回去。

3 而且你去修改这段代码,如果是远古代码,原作者已经离职,这还好说,如果原作者是你的同事,人家会怎么想?不少人会认为,你去干涉了他的工作,或者冒犯了他的工作领域。

当然如果你改得有道理,或者没有引入问题,那还好说。但如果引出问题,或者问题出在你改动代码所在的类甚至是模块,那么出问题,别人真会说,本来是好的,但xx改动后出了问题。这样哪怕原来代码就有问题,你一时半会还很难说清楚。

4 站在项目经理的角度来考虑,第一要义是能按时正常地把项目发布出去。这个过程中,哪怕有隐藏bug,但如果客户或测试没测出来,只要别让人说“发现了但不修改”,项目经理是没责任的。

具体来说,项目发布前会有套回归测试的流程,如果有隐藏bug,但回归测试没发现,出了问题,真可能是测试和开发一起分担。但如果发布前,有开发人员在功能正确的前提下,依然用所谓“代码重构”的理念去修改,那就属于多事。项目经理一般不会表扬,虽然不会批评,但至少会腹诽。

5 和项目发布相关的所有人,其主观上一定是期待项目能正确发布,或者是,至少别在我手上出问题。很多话只能说,比如期望代码高质量,或者代码架构好,这些话一定只是说给客户和领导听。

但如果真去照有些标准去做了,比如真去没事重构代码了, 大概率会增大别人的工作量。比如项目经理会因此担责,测试人员得多测,而且真出了问题,所有人都会承担连带责任。

当然如果修改的时候,你说你的出发点是为了代码质量或架构,那别人还真没法说,但这种事情尽量别多做。

6 当然开发项目时,确实得确保代码的质量,但这第一得有人牵头做,第二得有明确的标准。比如某项目在开发时,由项目经理或测试leader负责质量,是用某扫描工具,发现有问题,比如重复代码过多或命名不规范,会让人修改。

不过如果有人私下发起,这不免有越俎代庖之嫌,或者重构代码时不按规范随意修改,这就属于不可控的风险。

7 比如在面试中,有程序员说,我在做项目时,当看到现有代码有架构等方面的问题,我会顺手重构。那么这其实并不是加分项。或者是,比如有人说,自己经常会重构项目代码,那么有经验的面试官,大概率会质疑其项目的真实性。毕竟很多项目开发时间很紧,没有专门的时间来重构代码。

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

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

相关文章

力扣每日一题113:路径总和||

题目 中等 给你二叉树的根节点 root 和一个整数目标和 targetSum ,找出所有 从根节点到叶子节点 路径总和等于给定目标和的路径。 叶子节点 是指没有子节点的节点。 示例 1: 输入:root [5,4,8,11,null,13,4,7,2,null,null,5,1], targetSu…

《深入理解kafka》对于实际问题的理解

Q1:消息可靠性(不重不漏) 1.1 如何保证消息不丢 1.2 如何保证消息不重 Q2:积压/消费能力 2.1 线上积压排查思路 2.2 增加消费能力 Q1:消息可靠性(不重不漏) 理解可靠性前。介绍消息语义,即消息传递的标准 标准 丢失 重复 适用…

Redis-3 数据持久化

一.什么是数据持久化? redis是把数据存储在内存中的,而采用DRAM芯片存储的内存会面临断电导致数据丢失的问题,因此我们可以将redis在内存中的数据存储一份到磁盘中,用于内存数据丢失时的恢复,这个过程就叫做数据持久化…

完成单位投稿任务找投稿渠道不用精选10个1个就够了

在单位担任信息宣传员的这几年,我深刻体会到了“笔耕不辍”的艰辛与挑战。起初,面对单位的宣传需求,我遵循传统的投稿路径,即通过电子邮件的方式,一家接一家地向各大媒体投递稿件。那时的我,以为只要稿件质量上乘,自然能够获得青睐,却未曾料到,这是一条漫长而曲折的道路。 邮箱…

算法day03

第一题 179. 查找总价格为目标值的两个商品 本题采用前后指针和单调性规律可解; 解题思路如下: 1、设置前后指针 2、前后指针所指的两数之和大于目标数,右指针左移; 前后指针所指的两数之和小于目标数,左指针右移&…

“视频剪辑新境界:批量高效处理,画面虚化与播放速度调整一气呵成!“

在视频制作的广阔天地中,剪辑是赋予作品生命的关键环节。然而,面对大量的视频素材,如何高效地进行剪辑、调整,使每一帧画面都充满魅力,成为许多创作者面临的挑战。今天,我们为您带来一款颠覆性的视频剪辑工…

学习笔记:【QC】Android Q - IMS 模块

一、IMS init 流程图 高清的流程图参考:【高清图,保存后可以放大看】 二、IMS turnon 流程图 高清的流程图参考:【高清图,保存后可以放大看】 三、分析说明 1、nv702870 不创建ims apn pdp 2、nv702811 nv702811的时候才创建…

Objective-C的对象复制与拷贝选项

对象复制与拷贝 文章目录 对象复制与拷贝copy与mutablecopycopy与mutablecopy的简介示例:不可变对象的复制可变对象的复制 NSCopying和NSMutableCopying协议深复刻和浅复刻浅拷贝(Shallow Copy):深拷贝(Deep Copy&…

同步电机原理解析

同步电机 同步带年纪,顾名思义无论负载如何,都能以恒定的速度运转,它以高效率著称 这种恒速特性是通过恒定磁场和旋转磁场的相互作用实现的,与其他电机一样,同步电机由定子和转子组成,定子铁芯由硅片层叠而…

无人直播需要什么软件系统?最新AI实景自动无人直播软件:智能化引领直播拓客新时代

随着互联网的快速发展(无人直播招商加盟:hzzxar)直播行业已经成为商家品牌推广和商品销售的热门方式。近年来,人工智能技术的飞速发展,催生了一款令人惊叹的AI实景自动无人直播软件,为商家提供了全新的直播…

修改表空间的状态

Oracle从入门到总裁:​​​​​​https://blog.csdn.net/weixin_67859959/article/details/135209645 表空间有4种状态:联机、脱机、只读和读写。修改其中某一种状态的语句如下所示 设置表空间 tspace 为联机状态。 SQL>ALTER TABLESPACE space ONLINE: 设置表空间 tspa…

Node.js身份证实名认证接口、身份证识别API

翔云OCR身份证查验集合了身份证号核验,身份信息核验,身份核验。 基于翔云身份证识别接口的Node.js开发示例代码如下: var request require(request); var options {method: POST,url: https://netocr.com/api/recogliu.do,headers: {},fo…

google地图js,添加标记,以及infowindow信息弹窗

&#xff08;谷歌地图版本V3&#xff09; var contentString "<div classdevinfo><P>设备ID: BJ-20240507</p> <P>设备状态: 正常</p> <P>通讯信号: 89% </p> <P>设备位置: 中国</p> <P>剂量率: 988</p&…

鸿蒙开发接口Ability框架:【(StaticSubscriberExtensionAbility)】

StaticSubscriberExtensionAbility StaticSubscriberExtensionAbility模块提供静态订阅者扩展能力的类别的能力。 说明&#xff1a; 本模块首批接口从API version 9 开始支持。后续版本的新增接口&#xff0c;采用上角标单独标记接口的起始版本。 本模块接口仅可在Stage模型下…

SpringBoot之Zuul服务

概述 Spring Cloud Netflix zuul组件是微服务架构中的网关组件,Zuul作为统一网关,是所有访问该平台的请求入口,核心功能是路由和过滤。 目前公司业务就是基于Zuul搭建的网关服务,且提供的服务包括转发请求(路由)、黑名单IP访问拦截、URL资源访问时的权限拦截、统一访问日志记…

【退役之重学Java】如何保证从消息队列里拿到的消息顺序执行

一、场景 MySQL binlog 同步数据&#xff0c;比如大数据team。在MySQL中进行增删改查&#xff0c;将其 binlog 发送到 MQ 里面&#xff0c;到消费出来执行&#xff0c;这里就必须要保证其顺序执行&#xff0c;不然数据库就会错乱。 二、如何保证消息的顺序性呢&#xff1f; …

【python】模拟巴特沃斯滤波器

巴特沃斯滤波器&#xff08;Butterworth Filter&#xff09;&#xff0c;以其设计者斯蒂芬巴特沃斯&#xff08;Stephen Butterworth&#xff09;的名字命名&#xff0c;是一种具有平滑频率响应的滤波器。这种滤波器在频域中具有非常平坦的无波纹响应&#xff0c;直到它达到截止…

【springboot基础】如何搭建一个web项目?

正在学习springboot&#xff0c;还是小白&#xff0c;今天分享一下如何搭建一个简单的springboot的web项目&#xff0c;只要写一个类就能实现最基础的前后端交互&#xff0c;实现web版helloworld &#xff0c;哈哈&#xff0c;虽然十分简陋&#xff0c;但也希望对你理解web运作…

ssm115乐购游戏商城系统+vue

毕业生学历证明系统 设计与实现 内容摘要 如今社会上各行各业&#xff0c;都喜欢用自己行业的专属软件工作&#xff0c;互联网发展到这个时候&#xff0c;人们已经发现离不开了互联网。新技术的产生&#xff0c;往往能解决一些老技术的弊端问题。因为传统毕业生学历信息管理难…

构建跨平台应用的利器——UniApp

UniApp简介 UniApp的概念与特点 UniApp 是一款基于 Vue.js 的跨平台应用框架&#xff0c;它允许开发者使用相同的代码构建同时运行在多个平台&#xff08;如Web、iOS和Android&#xff09;的应用程序。UniApp 具有以下几个主要特点&#xff1a; 跨平台能力&#xff1a;UniApp …