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

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

相关文章

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定

Vue3项目开发——新闻发布管理系统(六)

文章目录 八、首页设计开发1、页面设计2、登录访问拦截实现3、用户基本信息显示①封装用户基本信息获取接口②用户基本信息存储③用户基本信息调用④用户基本信息动态渲染 4、退出功能实现①注册点击事件②添加退出功能③数据清理 5、代码下载 八、首页设计开发 登录成功后,系统就进入了首页。接下来,也就进行首页的开发了。 1、页面设计 系统页面主要分为三部分,左侧为系统的菜单栏,右侧

SpringBoot项目是如何启动

启动步骤 概念 运行main方法,初始化SpringApplication 从spring.factories读取listener ApplicationContentInitializer运行run方法读取环境变量,配置信息创建SpringApplication上下文预初始化上下文,将启动类作为配置类进行读取调用 refresh 加载 IOC容器,加载所有的自动配置类,创建容器在这个过程

Maven创建项目中的groupId, artifactId, 和 version的意思

文章目录 groupIdartifactIdversionname groupId 定义:groupId 是 Maven 项目坐标的第一个部分,它通常表示项目的组织或公司的域名反转写法。例如,如果你为公司 example.com 开发软件,groupId 可能是 com.example。作用:groupId 被用来组织和分组相关的 Maven artifacts,这样可以避免

2. 下载rknn-toolkit2项目

官网链接: https://github.com/airockchip/rknn-toolkit2 安装好git:[[1. Git的安装]] 下载项目: git clone https://github.com/airockchip/rknn-toolkit2.git 或者直接去github下载压缩文件,解压即可。

9.8javaweb项目总结

1.主界面用户信息显示 登录成功后,将用户信息存储在记录在 localStorage中,然后进入界面之前通过js来渲染主界面 存储用户信息 将用户信息渲染在主界面上,并且头像设置跳转,到个人资料界面 这里数据库中还没有设置相关信息 2.模糊查找 检测输入框是否有变更,有的话调用方法,进行查找 发送检测请求,然后接收的时候设置最多显示四个类似的搜索结果

maven发布项目到私服-snapshot快照库和release发布库的区别和作用及maven常用命令

maven发布项目到私服-snapshot快照库和release发布库的区别和作用及maven常用命令 在日常的工作中由于各种原因,会出现这样一种情况,某些项目并没有打包至mvnrepository。如果采用原始直接打包放到lib目录的方式进行处理,便对项目的管理带来一些不必要的麻烦。例如版本升级后需要重新打包并,替换原有jar包等等一些额外的工作量和麻烦。为了避免这些不必要的麻烦,通常我们

html css jquery选项卡 代码练习小项目

在学习 html 和 css jquery 结合使用的时候 做好是能尝试做一些简单的小功能,来提高自己的 逻辑能力,熟悉代码的编写语法 下面分享一段代码 使用html css jquery选项卡 代码练习 <div class="box"><dl class="tab"><dd class="active">手机</dd><dd>家电</dd><dd>服装</dd><dd>数码</dd><dd