项目难做,程序员难当,软件开发中的 9 大难题

简介: 是什么让项目变糟?何时起我们下班回家时开始盘算:“见鬼,我得离开”?下面是我们程序员不时要面对的一个问题清单,这些问题让我们筋疲力尽。

是什么让项目变糟?何时起我们下班回家时开始盘算:“见鬼,我得离开”?下面是我们程序员不时要面对的一个问题清单,这些问题让我们筋疲力尽。而通常我们又躲不掉,不得不设法去应付。

01 错误的团队

如果你不幸处在一个错误的团队中,问题则免不了。大家也许都还不错,但是当其中某人因为钱的事情不高兴,或者对琐碎的任务感到厌烦时,他就可能破坏团队的气氛。其他人可能只顾着自己的事业,这使得他们变成了糟糕的团队伙伴。某人会认为自己是在帮助这些人实现他们自己的事业目标。如果一个团队成员的知识太少,也可能出现不友好的情况。如果你从事的工作与你的技能不配,或者没有人能够帮你迈出第一步的话,你也可能陷入麻烦。

团队需要和谐。如果你有幸身处“分享同一个梦想”的团队,一切都很美妙。如果你是由无聊或自负之人组成的团队的一员,你可能会经历一段非常艰难的时光。

02 荒诞的需求

一些项目需求读起来简直是科幻小说,抽象,一点都不现实。有想象力当然很好,但想象力必须适应团队。如果项目团队中有许多应届毕业生,你不太可能在第一版就创建出基于云的最佳电子表格。

有些客户往往以为软件需求一句话就可以说清楚:“该产品必须像社交网站 X,只是有一点儿不同。”“事情不会太难,有公司已经提供了免费版。”“这只是一个留言板罢了。”这些需求最终导致极大的不满。客户从未获得自己满意的产品,开发者也根本没法儿满足客户,而且觉得自己难以胜任工作。

03 外行的期望

不清晰的需求导致了外行的期望,不仅如此,有时人们似乎把程序员当成了超人。

当你刚接手一个项目时,根本不可能成功调试有着 100 000 行代码的程序。无论是不是产品问题,程序员都需要时间先读懂代码,然后才可能修复它。

像“这只是一个按钮罢了”或者“老手程序员五分钟就搞定了”这样的话根本无济于事。除此之外,“五分钟的修复”也许正是需要修复的根本原因。

04 咖啡机下度夜

一些时候,超越身体极限,尽量把活干完是必要的。假设产品中存在一个根本性的软件故障,我们要尽力救援。这往往需要额外加班,工作到半夜甚至更晚。

软件的问题是如此关键,以至程序员往往被期望熬夜处理,直到问题解决。我们中最好的程序员曾被发现在咖啡机下方昏昏睡去,虽然他奋不顾身地想保持清醒,但最终失败了。在一些人的心目中,在咖啡机下睡觉显示了程序员对项目的认真。

虽然这样的生活有时很有趣,但长此以往会导致严重的问题。如果你的这种行为“修复”了事实上是管理不善的问题,那就更糟了。当需求变化时,或者由于公司政治致使项目管理者承诺了一个最后期限时,你就会遭受非常令人沮丧的经历:有家不能归,有床不能睡。

05 被忽略的非工作生活

程序存在软件缺陷,这很正常,无法完全避免。心理学家发现人们可以很容易地同时思考三件事。但如果数量超过三个,大多数人的思维都会出现问题。然而作为一名程序员,我们必须同时记得更多事情。

通常在程序员的周围有很多干扰,比如:

咆哮的项目经理; 没完没了的电话和会议; 在高压下工作; 或者是家庭、健康或财务问题。 一个程序员受到的干扰越多,编写出缺陷代码的可能性就越大。让一些分心的事可以保持在最低限度,以免他人受到影响。例如家庭生活,这是我们生命的重要一面,虽然有时它也相当无情。

无论谁在评估项目的预算,都需要安排一些额外时间考虑到程序员的非工作生活。不能仅根据项目成员的工作经验来计算预算额度,需要考虑他们的现状。为了正确地估算,你需要知道有人家里是否有个怀孕的妻子,大家是否都健康,或者是否已从之前疲惫的项目中恢复了元气。

忽视生活就意味着忽视风险或机会。

给一个精力充沛的人布置大量无聊的任务,意味着你错过了一个机会。而给一个家庭出现变故的人布置高度复杂的任务,则会增加风险。

如果程序员意识到自己的生活长期被忽视,这会使他感到沮丧和疲惫。

06 威胁产生的动力

威胁无疑不是一个好的激励策略,但仍然被广泛使用。“如果你不能熬夜加班,就不配当一名程序员,而应该去做一个园丁。”我的一名同事曾这样说过。

威胁会引起恐惧。除了黑暗外,害怕失去生存的基础也是人类最强烈的恐惧之一。

要是某人遭遇一阵威胁后,不得不在恐惧中工作,那他绝对是“职业倦怠”症的最佳人选。

07 无端变化的需求

项目经理走入房间,扔下新的需求,然后走人:这就是“直升机式管理”方式常见的场景。如同直升机着陆、扬尘并再次起飞。有些人精于此道。他们的大多数需求未经过深思熟虑,而且在项目实施的过程中毫无预警就改变了需求。

当需求不明确时,就会失去目标,任务永远无法结束。每一次会议都显得荒谬,所有讨论结果都是废话。最后,整个项目都被质疑,自己每天做的事情的意义也会受到怀疑。

08 贪婪

在现代社会中,如果你不能决定像僧人那样生活,你就需要金钱维持生存。

在某些场合下,公司——嗯,我们还是说公司的管理层吧——他们会竭力从项目中榨取每一分钱,对雇员看都不看一眼。

2012 年,富士康中国公司(它是苹果公司的合作伙伴)发生了一系列抗议运动。工人要求改善工作条件。

在西方国家,你可能被迫一直住最廉价的酒店,坐最廉价的交通工具,而且使用最廉价的办公设备,即使你负责的项目非常成功,为公司带来的利润丰厚。

节省本该花在员工身上的钱,从而证明公司的盈利能力是多么强,可能是管理层犯下的最糟糕的错误。我见过很多人因此而离开公司。

09 其他成见

对于那些让程序员沮丧的事情,我可以写一整本书,在本章我们就已经看了其中一些。

这里有一些更多的成见,你也许听说过。

比如,伟大的程序员

如果能用 Y 语言写代码,就能用 X 语言写代码。 可以迅速地解决问题,其中大多数能在一分钟内搞定。 不会写有缺陷的代码。 不需要编写测试代码。 喜欢深夜还在为客户编写代码。 不在计算机旁或办公室里也能调试代码。 了解关于硬件、最新的 IT 趋势以及框架等的一切,无所不知。 不与客户交流就能够理解客户的意思。 熟悉各种操作系统,从底层到上层,包括每一种移动设备上的系统。 可以编写运行在每一种设备上的代码,并且无需重新编译,无需设备转换,无需付出额外的努力。 这个成见清单可以说是无穷无尽的。我们无法教育人们停止相信诸如此类的故事。即使是专家也无法做到。相反,我们需要基于日常准则保护自己免受成见的干扰。

工作一到五年的程序员朋友面对目前的技术无从下手,感到很迷茫可以加群744677563,里面有阿里Java高级大牛直播讲解知识点,分享知识,课程内容都是各位老师多年工作经验的梳理和总结,带着大家全面、科学地建立自己的技术体系和技术认知!

相关文章
社区活动礼品兑换攻略
社区活动礼品兑换攻略
13944 1
|
机器学习/深度学习 测试技术 计算机视觉
【YOLOv8改进】DAT(Deformable Attention):可变性注意力 (论文笔记+引入代码)
YOLO目标检测创新改进与实战案例专栏探讨了YOLO的有效改进,包括卷积、主干、注意力和检测头等机制的创新,以及目标检测分割项目的实践。专栏介绍了Deformable Attention Transformer,它解决了Transformer全局感受野带来的问题,通过数据依赖的位置选择、灵活的偏移学习和全局键共享,聚焦相关区域并捕获更多特征。模型在多个基准测试中表现优秀,代码可在GitHub获取。此外,文章还展示了如何在YOLOv8中应用Deformable Attention。
|
11月前
|
JSON Java 开发工具
Java服务端集成Google FCM推送的注意事项和实际经验
公司的app要上海外,涉及到推送功能,经过综合考虑,选择Google FCM进行消息推送。 查看一些集成博客和官方文档,看的似懂非懂,迷迷惑惑。本篇文章除了将我实际集成的经验分享出来,也会对看到的博客及其中产生的疑惑、注意事项一一评论。 从官方文档和众多博客中,你会发现Java集成FCM推送有多种实现方式,会让生产生文档很乱,不知作何选择的困惑。
262 0
|
Java 测试技术 数据库连接
SpringBoot单元测试 Mybatis:增删改查
SpringBoot单元测试 Mybatis:增删改查
1146 0
|
机器学习/深度学习 人工智能 算法
无监督学习与生成式人工智能(MEAP)(一)(1)
无监督学习与生成式人工智能(MEAP)(一)
147 0
|
弹性计算 黑灰产治理
阿里云学生服务器购买指南2023年新版教程
2023阿里云学生服务器免费领取,先完成学生认证即可免费领取一台云服务器ECS,配置为2核2G、1M带宽、40G系统盘,在云服务器ECS实例过期之前,完成实验与认证任务,还可以免费续费6个月,阿里云百科来详细说下2023阿里云学生服务器活动、学生机配置、免费时长及学生服务器领取条件
1409 0
|
移动开发 前端开发 开发工具
智慧校园信息化H5端App的软件开发设计文档
智慧校园信息化H5端App的软件开发设计文档
206 0
|
Web App开发 安全 JavaScript
Electron 进程间通信的实现方案
本文讲解 Electron 应用开发种,如何调用相关 API 或者使用相关模块达到 Electron 跨进程通信。
11447 3
|
传感器 编解码
Arduino温湿度传感器DHT11(含代码)
Arduino温湿度传感器DHT11(含代码)
739 0
Arduino温湿度传感器DHT11(含代码)
|
区块链 C++ 计算机视觉
C++工程封装成安装软件.exe(非常实用)
C++工程封装成安装软件.exe(非常实用)