程序员不单单只有技术的深度,更应该有广度的提升,比如产品思维,项目管理,运营,时间管理,沟通,领导力,.压力管理,冲突管理,目标管理,经济学,博弈论,商业模式,财报入门等等.
看看 程序员,技术主管(Leader),架构师 有什么区别:
技术管理最重要的两个任务:
在我眼中,我认为技术管理并不是真正的纯管理人员,只是一个懂技术的服务人员与领路人,有时候可以说是你成就了大家,倒不如说大家成就了你,也可以说是大家双赢.
技术管理者需要为团队成员服务,有人需要资源就给协调资源,有人不明白目标就帮助他明确目标并制定其个人目标,
不同的模块间接口无法确认就组织相关人员讨论,xxx任务完成的好就给予明确肯定,
xxx所从事的技术方向迷茫就协助找到发展方向,
有人突然情绪低落效率低下及时发现背后的原因并在必要时提供支持… …(感觉是不是像保姆)
影响力的六大原则也是应该知晓的:互惠原则,承诺一致,社会认同,喜好,权威,稀缺
激励别人无非就两个因素(基础因素与动力因素):
技术管理者还需要几点,以身作则,勇于承担责任,共情能力,时刻牢记公司,团队,项目目标,情绪控制,不传递负能量,不耻于下问 ,复盘 等等.(慢慢改变吧!!!)
每天进步一点或者看一会书,1个月,1年,坚持下来,慢慢就提升了,时间复利就是我们最好的朋友
程序员的主流成长发展路线,是明显的“T”形路线,纵深是技术的深度,横向上,是广度方面的,当然也包括技术专业之外的领域。
建议看看《认知天性》中说的后刻意练习时代:
1.学习的东西需要进行检索
2.穿插练习,有助长期记忆.
3.反思是检索的一种
结论:平时可以尝试技术分享,讲解给别人听,重构代码,严格要求自己,写DEMO,或者自己写一个小项目等等来检索或者练习 自己学习的设计模式,性能优化,自定义view,动画等等知识点,有问题的再重点去学习,掌握. 后续也可以进行一些总结,反思,优化.
OKR目标管理学习:
平时很忙如何学习,建议做好年计划(列出目标与关键结果),分解为月计划,再细致分解到周计划,然后每周或者每个月检查成果.
提升的途径有几种方式:
阅读优秀源码,不只是单单阅读,要理解别人为何这么做,要是你做会如何做,最后可以尝试自己写一个类似的检索与练习下.
用指标严格要求自己: 代码风格,内存,CPU,APP大小等等优化,交付时间,BUG率,冒烟测试通过率等等
讲给别人听,就是可以做一些分享,或者平时解决问题,能不能说明白原理,眼睛过的,不代表你真的懂.
业余时间:
避免能力陷阱:
做的越多就越擅长,越擅长就越愿意去做。这就容易被你当前的状态所局限。
这样的一个循环能让我们在这方面获得更多的经验,但却容易陷入能力陷阱,在其他方面无法突破。
如何分配任务,跟踪进度,沟通,等等,是一个刚进入 技术管理者 应该必备的技能.
按照公司,团队 实际情况,合理应用项目管理手段(比如敏捷,瀑布等等).
在开发前,建议项目的团队成员需要知道任务的优先级,尤其是多任务并行的时候.
也可以善用清单 对于项目各个环节进行把控检查.
建议拿到或者讨论 项目或者需求,第一件需要做的事情就是技术可行性评估.
项目或者需求,我感觉执行应该符合 Smart原则.
各个项目需要分清 轻重缓急.
先不要急着给出承诺以及开发计划,先了解几个方面:
任务分解需要搞清楚几件事情:
顾名思义,就是将一个项目分解成N个小任务,参考敏捷开发的需求池概念。
开发任务分解(将一个或者多个需求分解成几个开发任务),定人,定时间(开发周期)。
技术选型(适配分辨率,Rxjava,网络请求库等等),架构,技术难点,风险 需要暴露出来,包括选用新技术也需要考虑几个方面(学习,招聘,时间,机会成本,风险也需要考虑).
比如,开发一款影视工具,有影视搜索,影视详情等等. 影视详情可以分解出很多小任务或者实际的开发任务(API接口 2天,界面 3天,逻辑代码1天,设计资源 等等)
1.对于需要使用的新技术,要估算学习和调研的时间。
2.我们需要编写什么样的接口?
3.我们需要创建什么样的架构?
4.我们需要更新哪些表?
5.我们需要更新或是编写哪些组件?
6.根据统计,每个程序员每天的有效工作时间是5个小时左右,其他时间都被沟通,喝水,休息,上洗手间等占据,所以如果某个任务估算超过5个小时,那就代表了这个任务完成需要超过一天的时间。
7.对于开发任务,估算尽可能的细,一般来说,每个任务的估算不应该超过5个小时,如果超过5个小时,就应该再把这个任务细分。只有尽可能细的估算任务,总的时间是大概精确地,因为估算时间是一个正态分布,有的任务估算的时间偏大了,有的时间任务估算的时间偏小了,估算越细,总体下来估算还是准确了。
注意几点:
也可以尝试改善分配工作的方式:所有任务列出来,然后进行分配(每个人从任务池挑选适合自己的,自己想做的)
不是安排了开发任务就放任不管了,需要进行进度跟踪。
可以 每天的站会 也 可以单独的沟通,主要是为了 提前发现问题,对 进度,风险把控。
站会需要关注的3个问题:
站会注意事项:
站会只是提了一个方式,根据实际情况而定,如果大家都加班到了10点,你还一大早9点开站会或者开会同步问题,我想大家心里一定是TMD的,换位思考,共情下.
将所有的需求列入需求池,按照每周的开发计划来,不急就排到下周或者下下周,排期.
如果真的很急,那就找上上级以及相关人员商讨,任务的优先级,看看那些需要扔出来的.
比如 有需求 A1, A2, B1, B2 正常弄,中间插入 C1,说的很急,必须这周完成,那么找上上级以及相关人员商讨,如果B2优先级不高,那就排到下周去.
多任务并行需要考虑优先级,人力资源等等问题.
作为技术管理,一定要确保团队目标与公司目标一致、个人目标与团队目标一致,只有这样,才能产生协力,有效实现预期。
让每个人都有参与感(共同制定团队目标和个人目标. 让员工参与到上层目标分解到团队目标,团队目标分解到个人目标的过程)
三种目标(公司目标,团队目标,个人目标)[必须符合Smart原则]
团队,公司,个人目标一致,才能产生协力,有效实现预期.
要将团队成员的个人目标与团队相结合,就必须理解下属的痛苦,快乐,为何在这里工作等,
针对每个具体的个人来考虑团队目标对于他个人的意义.
Smart原则:
OKR(“O”就是目标,—Objectives,“kr”即关键结果——Key Results)
比如定了目标,提升团队的10%效率,关键结果 有 公共库,统一开发环境等等.
沟通 是 无论技术人员,还是技术管理者,都应该必备的被动技能
有效的反馈机制:
1.沟通应该形成闭环
2.沟通最重要的环节,倾听,第一,体现对对方的尊重;第二,通过聆听别人把话讲完、讲透,更容易理解别人所要表达的真正含义。有效聆听才是沟通中最为重要的。
3.还有最后一个,需要注意,情绪的控制,一切的沟通是围绕解决问题的,不是争吵,更不是抵触情绪,会给别人留下不好合作的印象.
首先是倾听,澄清倾听后的理解,提出自己的观点,最后确认对方是否了解我们的观点.
不要进行‘信息过滤’,对上要如实报告,对下要如实传达
向上管理以及沟通搞清楚几个问题:
需要做到的几件事情:
主动,持续,周期性的让上级给你反馈,定期和上级沟通,了解他对你的评价,聆听他的建议(一方面汇报自己的工作,让他知道你的状态,另一方面管理过程遇到的困惑抛出来,请他指点下).
其实,对待技术人员最要紧的两个字就是——尊重。
如果我们能给他们足够的尊重,他们就一定会配合我们的工作.(其实无论是技术人员,还是其它人,我们都应该尊重别人)
多和下属沟通交流,了解他的生活,工作,真正地关注,关心,倾听对方。(比如聊房子,车子,房贷,喜欢的球星,游戏等等)
可以定期进行一对一的沟通,回避与下属的沟通,就是放弃了彼此了解,建议信任的机会,团队会越来越消极… …
一对一沟通,首先对话前问自己(来自关键对话):
参考谈话过程:
1.开始时阐明目的,为沟通定调:比如,“今天想请你帮忙我,我这段时间管理上做的事情有什么效果”。“和你谈谈最近的工作结果,一起讨论下一步工作安排”。等等
2.分享事实经过和你的想法:比如,“月初引入每日站会… …担心给大家带来负担,因此想…” 。
3.征询对方的观点,鼓励对方做出尝试:比如,“我想知道你对这件事的看法”。“我希望听你坦诚地讲讲发生了什么事情”。征询对方观点,多用开放式问题。
推荐使用微信读书
《人人都是产品经理2.0》,《从零开始做运营》,《技术领导力:程序员如何才能带团队》,《程序员的成长课》,《解忧程序员》,《卓有成效的管理者》,《从技术走向管理——李元芳履职记》,《沟通圣经:听说读写全方位沟通技巧》,《关键对话》,《向上管理》,《商业模式》,《一本书读懂财报》,《经济学》,《行为经济学》,《影响力》,《敏捷相关书籍》,**《能力陷阱》**等等