本文共 507 字,大约阅读时间需要 1 分钟。
中午刚吃过饭,正准备打开网页看看新闻,张大胖在微信上问我:“老刘,你说我是高级程序员吗?”“我愣了一下:‘你?工作了六七年了,现在还带着十个人的团队,应该是高级程序员了吧?’”我不由自主地回应道。
“我总是觉得老李才是高级程序员吧,人家知识体系完整,基础扎实,精通xxx技术,开发了系统的核心模块。还有老方,代码写得极为优雅漂亮,还特别擅长解决疑难杂症。”我说出了心里的想法。
“我说:‘你说的都是高级程序员表现出的特质,在不同的公司对高级程序员的定义都不一样。’”
“张大胖似乎福了我的回答,他接着问道:“有没有比较通用的定义呢?””
“这个……”我思索了一阵,随即想起了Stevan Popovic在Quora上的回答,不由得决定分享给他。
“你这是犯什么错误了?客户管你咋样?!”我突然意识到自己又一次犯了一个低级错误。
不,等一下,慢点。这次不太严重,估计客户也看不出问题。你先回去写代码。
我归纳了繁琐的思路,终于通盘看了一下问题。这类错误可能性有三分之二是源于需求理解错误剩下的三分之一可能是代码结构或业务逻辑上的疏漏。
确保需求文档没有歧义是关键,我决定在项目开始前反复确认各个功能点的具体实现细节。
转载地址:http://uxvvz.baihongyu.com/