一次项目延期-从自我怀疑到反思内心的真实经历

2024-08-27 01:32

本文主要是介绍一次项目延期-从自我怀疑到反思内心的真实经历,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

阅读本文大概需要 6.66 分钟。

总有一段日子,我们要一个人经历;总有一段路程,我们要一个人走过,这是自我存在的认同,是回望自省,也是一点执拗。

上上周,接到一个比较大的需求,因为自己的个人原因,负责的一个模块延期了,导致部门整体项目进度受到影响,没有在规定的时间内上线发版。

当所有的团队开发对进度,前端、IOS、测试对完一轮进度发现是后端的问题,而这个功能点正好是我负责的,因为我的原因,导致项目整体阻塞,不能按时往前推进,测试上线,这个时候对于资历最浅的我来说,压力可想而知。

那段时间可以说是我这半年印象最深刻的一段日子,为了支持项目按时上线,连续主动加班两个周末,每天下班到家都已经快凌晨了,每天上下班路上,吃饭睡觉都脑子里都想着写代码。

因为是自己的原因导致整个部门项目进度进度阻塞,那个时候就感觉到了一种不可避免的焦虑感,整个人开始对自己的能力产生了怀疑,一种犹然的挫败感席卷全身,我还记得有一天我的主管陪着我改 bug 工作到凌晨 2 点,等着我下班打车回家已经 3 点多了,第二天照常去公司上班。

现在想起来蛮愧疚的,因为我的产能不足导致我的主管也陪着我加班,毕竟有 deadline 在,这就是有压力就有动力,没有办法,只能自己扛住,不然就会出事故。

经过自己的努力,leader 的指导,和同事的帮助,现在项目已经稳定上线,我觉得很有必要对这个事情做一个回顾和总结反思,刚参加工作,觉得这样的经历也是难得的一种体验,在反思中吸取教训,以后保证自己不能犯相同的错误,用文字记录下来,重新回顾的时候也做加深理解。

如果读者朋友们能从我的文字里得到一些收获,那这篇文章就有它存在的价值了。

在互联网公司,其实每一个产品线都有很多的排期,你可以理解每个排期是在一段时间内实现一个需求,简单的理解就是实现一些功能,所以一个排期内如果需要实现的功能没有按期上线发版,就会影响到下一个排期的进度。

所以那会,各个组的 leader 在一起开会对接进度的时候,当别的团队能够按时往前推进的时候,轮到自己发言的时候,因为负责的模块还没有弄好阻塞了其它团队的工作。从而影响了整体项目的进度,这个时候就那种感觉就很不好了。

现在回想起来,导致需求 delay 的个人原因主要是下面这几点:

(1)第一次接触一个比较大的项目:开发周期 12 天;产出代码量 3k+,代码越多,意味着存在的隐患越多,可能产生的 bug 也越多,需要测试的地方也越多。

(2)由于自己缺乏相关经验,开发前期的需求沟通理解不到位,需求文档里需要实现的功能和存在的不清楚的地方没有及时讨论清楚;在没有想好的前提下就开始开发编码实现,因为没有想好,后面和客户端联调的时候就出现了一大堆的问题。

(3)出现了问题,必然要及时的解决,在解决问题的过程中,发现了很多开发前自己根本没有考虑清楚的细节:这个字段要不要下发?这两个接口能不能合并成一个?这个配置上线的时候同时考虑了 Android 和 IOS 的灰度版本吗?

这个功能需求文档里没有,但客户端需要实现需不需要和产品讨论确认?这次是实现这个功能,下次如果有类似的功能考虑了代码的可扩展性么?等等,总之,一次需求的发布,到编码,这其中,想清楚真的是很重要的一件事,不然必然会增加代码修改和维护成本。

(4)代码的任何改动,都需要及时和测试同学反馈清楚,并且到最后的 commit 最好每次加上修改的功能点。这样一旦因为某个原因需要回滚代码比较好查历史版本记录。

(5)当时在负责项目的时候,同时还有其它的事情在处理,那段时间真的一度感觉脑子已经不够用了,有点忙不过来,心力交瘁的感觉,为了支持项目按时上线,连续两周工作到很晚,因为没办法,自己负责的模块搞不定,有 deadline,搞不定也得硬着头皮搞啊,不然就出事故了。

总结反思:

经历了这次的事情,现在回过来头看,其实真的不算啥,但在当时真的是因为是第一次经历,所以感受也是比较深刻,有三点最大的体会:

第一个体会:不是所有的工作我们都有能力做好,有时候捅娄子的事情也常有,接受教训下次改进就好。但是在自己能力范围内就要全力保质保量交付,这也是一种靠谱的体现,对自己没把握的事情一定要及时和上级反馈。

在做一件事情之前,想清楚怎么做其实是很重要的,尤其是做开发的同学们,接了一个需求之后,尽量想清楚怎么做,考虑各种异常情况和边界条件,想清楚了怎么做之后其实这件事在心里就有整体的把控了,做到心中有数;工作量估算的时候一定要给自己留有余地免得双方都难受。

对于我们程序员来说,做一个需求从接到需求到上线的完整流程大致如下:

  • 需求分析(包括需求调研,需求讨论,需求确定,接口沟通确认)

  • 设计和编码(设计该功能实现细节,要用到什么技术等)

  • 系统实现(从软件代码技术层面实现功能)

  • 功能测试(包括开发自测,提交测试,回归测试,业务测试)

  • 需求上线(上线平台验收是否通过,代码是否回滚)

其实这上面每一个步骤都少不了,想清楚再去做真的是很重要的,希望我的读者朋友们还没入职或者刚参加工作的可以注意这一点。

第二个体会:关键时候还是靠自己。一般人面对问题有三种解决方式,一种是不去管它,二是找别人要答案,还有一种,是自己给自己答案。如果是你,你会选择哪一种,或者说,你已经成为了哪一种呢?

遇到问题,首先想到的不是去求助谁,而是想着自己该怎样去解决,这就要求你不断地学习,不断地思考,不断的踩坑试错,寻找新的方法,最终在有限的时间按时按量交付。这种能力我也在自己不断修炼,如何锻炼自己的能力,成为能独当一面的那种人,也是我们需要不断思考不断学习不断实践的。

第三个体会:在软件或者互联网公司,技术是安身立命最可靠的一种方式,因为一个人的技术强弱、产能高低是可以被明显地量化和评估,作为软件工程师,精进自己的专业能力是一种基本的职业素养。

以上就是我最近工作上的经历,全部都来自我自己亲身实践的“经验”。希望读者朋友看到这里能有一些收获。

当然每个人经历不一样。感悟也不一样,如果读者朋友自身有更深刻的经历,欢迎分享出来自己真实的经历,互相交流,共同进步,共勉。

PS:如果大家在阅读的过程中,有什么建议和看法,非常欢迎在下方留言,每个留言我都会认真看的

推荐阅读:

入职半个月的一些思考

在宇宙中心五道口上班,是怎样一种体验

认真的人,自带光芒!

原创不易

点个在看哦

这篇关于一次项目延期-从自我怀疑到反思内心的真实经历的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1110248

相关文章

部署Vue项目到服务器后404错误的原因及解决方案

《部署Vue项目到服务器后404错误的原因及解决方案》文章介绍了Vue项目部署步骤以及404错误的解决方案,部署步骤包括构建项目、上传文件、配置Web服务器、重启Nginx和访问域名,404错误通常是... 目录一、vue项目部署步骤二、404错误原因及解决方案错误场景原因分析解决方案一、Vue项目部署步骤

golang内存对齐的项目实践

《golang内存对齐的项目实践》本文主要介绍了golang内存对齐的项目实践,内存对齐不仅有助于提高内存访问效率,还确保了与硬件接口的兼容性,是Go语言编程中不可忽视的重要优化手段,下面就来介绍一下... 目录一、结构体中的字段顺序与内存对齐二、内存对齐的原理与规则三、调整结构体字段顺序优化内存对齐四、内

配置springboot项目动静分离打包分离lib方式

《配置springboot项目动静分离打包分离lib方式》本文介绍了如何将SpringBoot工程中的静态资源和配置文件分离出来,以减少jar包大小,方便修改配置文件,通过在jar包同级目录创建co... 目录前言1、分离配置文件原理2、pom文件配置3、使用package命令打包4、总结前言默认情况下,

python实现简易SSL的项目实践

《python实现简易SSL的项目实践》本文主要介绍了python实现简易SSL的项目实践,包括CA.py、server.py和client.py三个模块,文中通过示例代码介绍的非常详细,对大家的学习... 目录运行环境运行前准备程序实现与流程说明运行截图代码CA.pyclient.pyserver.py参

IDEA运行spring项目时,控制台未出现的解决方案

《IDEA运行spring项目时,控制台未出现的解决方案》文章总结了在使用IDEA运行代码时,控制台未出现的问题和解决方案,问题可能是由于点击图标或重启IDEA后控制台仍未显示,解决方案提供了解决方法... 目录问题分析解决方案总结问题js使用IDEA,点击运行按钮,运行结束,但控制台未出现http://

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时

C语言小项目实战之通讯录功能

《C语言小项目实战之通讯录功能》:本文主要介绍如何设计和实现一个简单的通讯录管理系统,包括联系人信息的存储、增加、删除、查找、修改和排序等功能,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录功能介绍:添加联系人模块显示联系人模块删除联系人模块查找联系人模块修改联系人模块排序联系人模块源代码如下

Python判断for循环最后一次的6种方法

《Python判断for循环最后一次的6种方法》在Python中,通常我们不会直接判断for循环是否正在执行最后一次迭代,因为Python的for循环是基于可迭代对象的,它不知道也不关心迭代的内部状态... 目录1.使用enuhttp://www.chinasem.cnmerate()和len()来判断for

SpringBoot项目中Maven剔除无用Jar引用的最佳实践

《SpringBoot项目中Maven剔除无用Jar引用的最佳实践》在SpringBoot项目开发中,Maven是最常用的构建工具之一,通过Maven,我们可以轻松地管理项目所需的依赖,而,... 目录1、引言2、Maven 依赖管理的基础概念2.1 什么是 Maven 依赖2.2 Maven 的依赖传递机

Vue项目中Element UI组件未注册的问题原因及解决方法

《Vue项目中ElementUI组件未注册的问题原因及解决方法》在Vue项目中使用ElementUI组件库时,开发者可能会遇到一些常见问题,例如组件未正确注册导致的警告或错误,本文将详细探讨这些问题... 目录引言一、问题背景1.1 错误信息分析1.2 问题原因二、解决方法2.1 全局引入 Element