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

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

相关文章

Maven项目中集成数据库文档生成工具的操作步骤

《Maven项目中集成数据库文档生成工具的操作步骤》在Maven项目中,可以通过集成数据库文档生成工具来自动生成数据库文档,本文为大家整理了使用screw-maven-plugin(推荐)的完... 目录1. 添加插件配置到 pom.XML2. 配置数据库信息3. 执行生成命令4. 高级配置选项5. 注意事

eclipse如何运行springboot项目

《eclipse如何运行springboot项目》:本文主要介绍eclipse如何运行springboot项目问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目js录当在eclipse启动spring boot项目时出现问题解决办法1.通过cmd命令行2.在ecl

SpringBoot项目Web拦截器使用的多种方式

《SpringBoot项目Web拦截器使用的多种方式》在SpringBoot应用中,Web拦截器(Interceptor)是一种用于在请求处理的不同阶段执行自定义逻辑的机制,下面给大家介绍Sprin... 目录一、实现 HandlerInterceptor 接口1、创建HandlerInterceptor实

Maven项目打包时添加本地Jar包的操作步骤

《Maven项目打包时添加本地Jar包的操作步骤》在Maven项目开发中,我们经常会遇到需要引入本地Jar包的场景,比如使用未发布到中央仓库的第三方库或者处理版本冲突的依赖项,本文将详细介绍如何通过M... 目录一、适用场景说明​二、核心操作命令​1. 命令格式解析​2. 实战案例演示​三、项目配置步骤​1

golang实现动态路由的项目实践

《golang实现动态路由的项目实践》本文主要介绍了golang实现动态路由项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习... 目录一、动态路由1.结构体(数据库的定义)2.预加载preload3.添加关联的方法一、动态路由1

Spring 缓存在项目中的使用详解

《Spring缓存在项目中的使用详解》Spring缓存机制,Cache接口为缓存的组件规范定义,包扩缓存的各种操作(添加缓存、删除缓存、修改缓存等),本文给大家介绍Spring缓存在项目中的使用... 目录1.Spring 缓存机制介绍2.Spring 缓存用到的概念Ⅰ.两个接口Ⅱ.三个注解(方法层次)Ⅲ.

一文教你Java如何快速构建项目骨架

《一文教你Java如何快速构建项目骨架》在Java项目开发过程中,构建项目骨架是一项繁琐但又基础重要的工作,Java领域有许多代码生成工具可以帮助我们快速完成这一任务,下面就跟随小编一起来了解下... 目录一、代码生成工具概述常用 Java 代码生成工具简介代码生成工具的优势二、使用 MyBATis Gen

springboot项目redis缓存异常实战案例详解(提供解决方案)

《springboot项目redis缓存异常实战案例详解(提供解决方案)》redis基本上是高并发场景上会用到的一个高性能的key-value数据库,属于nosql类型,一般用作于缓存,一般是结合数据... 目录缓存异常实践案例缓存穿透问题缓存击穿问题(其中也解决了穿透问题)完整代码缓存异常实践案例Red

SpringBoot项目中Redis存储Session对象序列化处理

《SpringBoot项目中Redis存储Session对象序列化处理》在SpringBoot项目中使用Redis存储Session时,对象的序列化和反序列化是关键步骤,下面我们就来讲讲如何在Spri... 目录一、为什么需要序列化处理二、Spring Boot 集成 Redis 存储 Session2.1

springboot+vue项目怎么解决跨域问题详解

《springboot+vue项目怎么解决跨域问题详解》:本文主要介绍springboot+vue项目怎么解决跨域问题的相关资料,包括前端代理、后端全局配置CORS、注解配置和Nginx反向代理,... 目录1. 前端代理(开发环境推荐)2. 后端全局配置 CORS(生产环境推荐)3. 后端注解配置(按接口