程序员管理思维修炼,只需要反复阅读本篇-程序员宅基地

技术标签: 项目管理  敏捷开发  编程语言  人工智能  软件开发  

一个技术精湛的程序员,只要有机会,就有可能被公司提拔为项目管理人员,掌控项目中的一切。

 

图片来源于Pexels 

但所谓权力越大责任越大,要想成为一个合格的项目管理人员,我认为最重要的首先是扭转自己的思想。

正如老子说的“道为体,术为用。”我们的思维模式改变了,各种管理的方法和工具自然的就会去学习使用了。

正所谓“有道者术能长久,无道者术必落空。”所以在本文中,我就和大家聊一聊管理中的“道”,我们程序员如何修炼管理思维?我们要先懂得道理,再去学怎么做。

你不是一个人在战斗

很多兄弟刚转型管理的时候,更多的关注事,而不是关注人。不断的把任务分派下去,到点验收,期待得到一个好的结果。

遇到任务出问题,马上跳出去指责。“你为什么又没完成!”,“怎么这点东西都做不好!”。

这样只能导致一遍又一遍的出问题。你想想,你可能是因为业务精湛才被提拔为项目经理,其他同事业务上没有你那么娴熟,无可厚非。

而任务分派下去以后,你是否需要和同事聊聊难点,说说你的想法,有问题给予一些简单的指导。

出问题的时候,首先应该引导而不是指责。

有的兄弟刚转型管理的时候,一旦遇到同事完不成的任务,遇到的难点,马上跳上去三下五除二一顿敲,解决问题后,不留下一片云彩,挥袖而去。

这些兄弟总会替代同事做他们自己本应该做的事情导致同事得不到成长,而自己则搞的很疲惫。

我想有一点我们需要明白:项目经理是团队中的指战员,掌控着整个团队前进的方向和打法。你不是一个人在战斗,你的行为影响着整个团队的战斗力。

作为程序员,我们习惯了单兵作战,不断的钻研打磨自己的技术,就能高效的完成任务,提高战斗力。而项目经理,是需要指挥一群人,去打赢一场又一场的战斗。

所以我想说的是:

  • 你要给予团队里的同事包容,给予引导而不是指责。

  • 给予每个人锻炼的机会。事无巨细的帮助或者亲手操刀,只会毁了团队。

  • 夸张点说,你决定了整个团队的战斗力,请为同事负责也为自己负责。

  • 培养人是你的职责,团队的进步才是真的进步。

 

图片来源于Pexels 

 

并行工作可以拯救你,也可以毁了你

做了管理以后,你会发现自己被各种事情同时缠身。你不仅仅要处理技术那点事了,你可能同时在处理多件事情。

你要维系干系人、要做任务 WBS(工作分解结构)、要沟通需求、要项目演示、要协调团队关系、要处理各种紧急情况、甚至于要填报材料、要写合同、要解决客户乱七八糟的问题等等。

总之刚开始的时候你会发现,你事情多的做不完,被各种事情缠的脱不开身。但这又是你的工作职责,必须要去处理。

我们程序员最擅长的就是抽丝剥茧,把一个复杂的需求逐渐理清,结构化后编写成代码。同样的,你也需要在这些纷乱的任务中抽丝剥茧,有章有法的去处理开来。

这些事情如果处理不好,你会发现自己一直处于忙碌之中,而不知道自己到底在忙些什么。

长此以往,你会对自己失去信心,项目也会一塌糊涂。但从另一个角度来说,如果你能有条有理把这些杂乱的任务整理清楚,你一定会有质的飞越。

所以我想说的是:

  • 拥抱混乱,但别陷入其中。

  • 这是展示你真正技术的时刻,如何做好个人时间管理,是你最重要的一课。


码代码很重要,但其他事情也同样重要

我们程序员总认为:码代码才是正事,其他事情都是扯淡。但你别忘了,你肯定也经历过需求改来改去导致的痛苦、设计稿一改再改带来的重复劳动、没有设计就开发导致的各种问题。

既然我们身为程序员的时候,已经经历过这些苦楚,那为什么要让我们的同事再经受一遍呢?

所以,请重视项目前期的阶段。去搞定干系人、去敲定需求、去定稿设计、去指导代码设计。这些工作完成的越好,开发过程越顺利,项目进度越有保障。

身为项目经理,你需要额外做很多事情,保障项目的进度。很多事情等到开发阶段再介入,你会发现为时已晚。莫要坑了同事也坑了自己。

所以我想说的是:

  • 先设计后开发。

  • 防范于未然的能力,比救火能力更重要。

不断挖掘,发现本质

我们程序员啊,总是亦或者是习惯了别人说什么,我就做什么。但其实我们也应该多问问为什么。

而项目经理我认为需要有透过表象发现本质的能力:

  • 需求来临的时候,你能否透过现有的需求发现客户更深层次的需要? 

  • 某同事任务完不成的时候,你能否透过日常点滴发现他完不成的原因? 

  • 测试团队和开发团队起冲突的时候,你是否能透过日常的交流发现矛盾的根源? 

  • 团队士气低落的时候,你能否透过大家的表现悉知团队状态低落的问题所在?

首先,要想做到一步到位透过表象发现本质我认为是很难的,需要大量的锻炼。

但我认为我们保持一颗好奇之心,就能把问题的本质掌握的八九不离十。不断给提出问题,同时去挖掘问题的答案。

举个例子:

  • 客户:“我想造一架飞机。”

  • 项目经理:“您为什么想造一架飞机呢?造完飞机还需要建飞机场才能飞呢。您是要去什么地方吗?”

  • 客户:“我是想去西班牙,觉得有架飞机比较方便。”

  • 项目经理:“您去西班牙做什么呢?是旅游吗?去西班牙的话,可以搭乘现有航班和渡轮也可以。”

  • 客户:“我这不是想去巴萨罗那看看比赛吗。”

  • 项目经理:“咱中央五台不是有直播吗,也可以看的。去巴萨罗那成本比较高。”

  • 客户:“我觉得去现场看比较有气氛,这点成本我能负担。”

  • 项目经理:“好的,那咱搭乘国际航班去可以吧?”

  • 客户:“好的,没问题。”

以上,客户的最根本需求是要到巴萨罗那现场去看球赛。而他的想法大概是要过去得有飞机,所以提出了造飞机的需求。

而项目经理在不断的交谈过程中,一次次的给出新方案,以探寻客户最需要的东西和摸索客户的想法(例子中为性价比和体验,客户更想要体验)。 

假设交谈过程中发现客户就是想要造架飞机,你也要告诉他飞机造出来了还要建飞机场。让他权衡成本是否可以接受。

不要飞机造出来了没地方起飞,这不光是客户的问题,是你没给客户提供完整的方案。这就叫做发现本质。

 

图片来源于Pexels  

以人为中心,而不是机器

我们程序员天天和机器打交道,习惯了非 0 即 1 的二进制生活。

但项目经理是需要和人沟通的,与人打交道。所以面对我们的同事,面对整个团队。应该多考虑人,以人为中心。

所以我想说的是:

  • 减少应激反应,多听取别人的说法,不要急于反驳。

  • 保持同理心,多从同事的角度想想,出错前做好预防工作。

  • 不要轻易给同事下结论,贴标签。人都是会改变的,这次不行不代表下次也不行。

  • 不能为兄弟们挡刀并引领兄弟们前进的老大是不值得追随的,弟兄们在你手下做事受尽委屈,争不了一口气,那这个老大也做不长。

放弃完美,是走向完美的路

我相信大多数程序员都有个毛病,追求完美。代码格式要最舒服,代码逻辑要最简洁,细节一抠再抠。就像强迫症一样,追求自己代码的完美。作为程序员来说,这是一个非常棒的习惯。

但作为项目经理来说,我们最需要的是平衡。一味的追求完美,会导致项目成员压力大增,成本不可控制。

作为项目经理来说,我们都希望自己带的项目细节无可挑剔,功能一应俱全,代码质量无懈可击,团队氛围融洽得体,项目质量高的无以复加,项目周期如约达成。

但其实项目里,所有事情都是互相平衡的。工期和细节打磨之间的平衡、成本与需求开发的平衡、批评与赞扬之间的平衡等等。

平衡是一方面,另一方面是迭代。保持迭代,一步一个脚印的把项目逐步推进。

所以我想说的是:

  • 把握平衡的尺度,是项目逐步趋于完美的路。

  • 不要追求一步到位,完美是迭代出来的。

少写代码可以,脱离技术不行

以上都是针对项目管理说的,而这最后一条,是为了引起各位的警惕。

我们上面说会有很多琐事缠身,可能导致你几乎没有写代码的时间了。这是正常的也是正确的,你的工作不是去当机枪手,你的工作是指挥大家战斗。

但这就代表我们要脱离技术了吗?我认为不是这样的。我们可以少写代码,但我们不能抛弃技术。

我有个朋友告诉我说:不要过早涉足“纯管理岗位”。我想他的意思,就是告诉我技术乃是一个软件开发的项目经理安身立命的根本。

我们程序员做项目管理,最大的好处就是,不会出现外行指导内行的情况。所以我们即便转型了,也要时刻保持对技术的敬畏和对技术的关注。

你可能不需要对各种技术的细节了解的特别透彻,但要心里有底,知道各种技术的适用范围、使用条件、优势劣势等等。保证在项目需要的时候,能够快速选型。

而作为一个项目经理,最大的一个好处在于可以让团队同事去学习,让他学习整理后来教你,以达到快速学习的目的。

所以我想说的是:

  • 不要抛弃技术,它总有一天会拯救你。

  • 学如逆水行舟,不进则退。

 

图片来源于Pexels  

 

后记

程序员的管理思维修炼就写到这里。明白了道理之后,大家再去练习工具,练习方法,才会卓有成效。

总结下来,我们要锻炼的管理思维如下:

  • 从个人到团队的转变。

  • 从专心做一件事到同时处理多个任务的转变。

  • 从只关注点到关注面的转变。

  • 从说什么是什么到为什么的转变。

  • 从追求完美到掌握平衡的转变。

以上,就是我和大家分享的内容,希望越来越多志在管理的程序员,能够顺利走上管理岗位。

作者:李雪涛(zer0Black)

简介:主要从事项目群管理、需求分析、系统设计工作。带领 20 余人团队攻关在汽车领域一线,参与汽车领域设计、制造、试验测试、销售全阶段信息化改造。现任天津盛扬信远科技有限公司项目经理。

编辑:陶家龙、孙淑娟

来源:51CTO技术栈

精彩文章推荐:

阿里6年,我的技术蜕变之路! 2020-08-14

雷军创业十年演讲全文!创业艰辛、乘风破浪、一往无前 2020-08-12

技术总监反思录:我是怎么失去团队掌控力的? 2020-08-09

CTO 技术管理的“三板斧” 2020-07-25

技术管理者必备管理模板 2020-07-20

   END     #接力技术,链接价值#

点分享点点赞点在看
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/k6T9Q8XKs6iIkZPPIFq/article/details/108138228

智能推荐

常用的原型开发工具-程序员宅基地

文章浏览阅读67次。1、Axure RP(Rapid Prototyping)Axure(读音为Ack-Sure)无疑是目前最受关注的原型开发工具,其能通过组件的方式帮助网站或软件设计师快速建立带有注释的原型(流程图、线框图),并凭借自定义可重用的元件、动态面板以及丰富的script能够建立基本功能或页面逻辑的动态演示文件。Axure借鉴了office的界面,能够让用户快速上手,并且提供了..._程序员原型法常用工具

nuiapp请求网络_uni-app 接口 - 网络请求-程序员宅基地

文章浏览阅读145次。1、 uni.request(OBJECT) 发起网络请求参数名 类型 必填 默认值 说明url String 是 开发者服务器接口地址data Object/String/ArrayBuffer 否 请求的参数header Object 否 设置请求的 header,header 中不能设置 Referer。method String 否 GET (需大写)有效值:OPTIONS, GET...

Vim命令学习参考_hadoop vim是什么操作-程序员宅基地

文章浏览阅读368次。1. 关于Vim1.1 Vim的几种模式2. 启动Vim3. 文档操作4. 光标的移动4.1 基本移动4.2 翻屏4.3 标记5. 插入文本5.1 基本插入5.2 改写插入6. 剪切复制和寄存器6.1 剪切和复制、粘贴6.2 文本对象6.3 寄存器7. 查找与替换7.1 查找7.2 替换7.3 正则表达式8. 排版8.1 基本排版8..._hadoop vim是什么操作

应用加速,数字人民币接入多地交通出行场景 | 产业区块链发展周报-程序员宅基地

文章浏览阅读3.1k次。摘要产业动态:微众银行多方大数据隐私计算平台通过信通院权威评测欧洲最大移动运营商沃达丰将为AI智能协议移动终端提供移动通信服务汇丰银行加入迪拜经济的阿联酋KYC区块链平台重庆市先进区块链研..._交通联合 小额支付

大数据毕设分享(含算法) 机器学习二手房价格预测及可视化系统(源码+论文)_数据挖掘二手房价预测-程序员宅基地

文章浏览阅读850次,点赞23次,收藏24次。​ 通过整个项目的实践,我们亲身体会了数据挖掘的那张路线图,预处理、分析之后发现问题(Knowledge),再进行新的处理,再重新分析挖掘,做评估,然后发现新的问题,再从头开始,在这几个过程的循环往复中完成了整个项目。_数据挖掘二手房价预测

input框 下面 紧跟着div弹出层,js取top left数值[实例]_input触发弹出层-程序员宅基地

文章浏览阅读3.6k次。var setSearchFlag; function showSearch(obj){ clearSearchFlag(); var w3c=(document.getElementById)? true:false;//w3c 标准 var ns6=(w3c && (navigator.appName=="Netscape"))? true: false;//Netsca_input触发弹出层

随便推点

olat中解决查看gui_demo源代码异常或debug模式下查看源代码异常_guidemo_main不显示-程序员宅基地

文章浏览阅读1.2k次。出现这种异常是因为没有设置 project.build.home.directory 参数,系统找不到源代码文件的位置。解决办法:1.首先下载源代码,可参考如何下载olat源代码并在eclipse中查看2.在部署的服务中找到 olat.local.properti_guidemo_main不显示

自定义View-Rect和RectF_android根据rect坐标添加控件-程序员宅基地

文章浏览阅读1.4k次。Rect 类定义了一个矩形结构,同样实现了 Parcelable 序列化接口。Rect 类定义了 left、top、right、bottom 四个成员变量,我们需要正确理解这 4 个成员变量的作用:left:矩形左边线条离 y 轴的距离top:矩形上面线条离 x 轴的距离right:矩形右边线条离 y 轴的距离bottom:矩形底部线条离 x 轴的距离矩形是一种非常常见的图_android根据rect坐标添加控件

CCS5导入工程时出错:Issues that may require your attention were encountered while importing the projects-程序员宅基地

文章浏览阅读2.4w次,点赞10次,收藏27次。1.出错CCS5.5.0导入工程(Import CCS Eclispse Project)时出错:Issues that may require your attention were encountered while importing the projects ,如下图:2.原因是由于文件夹名(例如f28335_Sci_Update_Flash_first)和文件夹中的工程名

Android4.0 Toast显示问题分析_安卓4.0不支持uni.showtoast-程序员宅基地

文章浏览阅读8.9k次,点赞3次,收藏4次。在修复RUI桌面在4.0系统下的提示信息不完善的Bug过程的一些思路与大家分享一下。Bug描述:RUI在2.2的系统点击推荐图标下载后,就会进入下载队列中下载,如果再次点击相同的图标就会使用Toast提示“**已经在下载队列中”。但是在4.0的系统就会出现异常,第二次点击相同的推荐图标时没有出现Toast提示。相关源码:public static void showMe_安卓4.0不支持uni.showtoast

服务器无法与DeviceNetBT_Tcpip_{670E1543-79C1-485C-9B4B-835CE3BA37B3}传输相绑定-程序员宅基地

文章浏览阅读3.3k次。在运行 Windows Server 2003 的计算机上,您可以根据需要对所选的客户端关闭 TCP/IP 上的 NetBIOS (NetBT)。如果您希望只使用 DNS 在一台指定计算机(该计算机用于您网络中的专门角色或安全角色)上提供名称注册和解析,则您可以选择为该计算机上安装的一个或所有网络适配器关闭 NetBT 服务。配置要关闭 WINS/NetBT..._服务器无法与传输绑定,因为网络上的另一部计算机具有相同的名称。服务器无法启动

NYOJ 118 修路方案(次小生成树)-程序员宅基地

文章浏览阅读806次。修路方案时间限制:3000 ms | 内存限制:65535 KB难度:5描述南将军率领着许多部队,它们分别驻扎在N个不同的城市里,这些城市分别编号1~N,由于交通不太便利,南将军准备修路。现在已经知道哪些城市之间可以修路,如果修路,花费是多少。现在,军师小工已经找到了一种修路的方案,能够使各个城市都联通起来,而且花费最少。但是,南

推荐文章

热门文章

相关标签