高效程序员工作法(一)

目录

前言:

 一、高效程序员的思考框架

思考框架:

四个思考原则:

以终为始:

任务分解;

沟通反馈;

自动化:

一句话总结:

二、 以终为始:如何让你的努力不白费?

一句话总结:

三、 DoD的价值:你完成了工作,为什么他们还不满意?

 一句话总结:

四、 接到需求任务,你要先做哪件事?

一句话总结:

五、持续集成:集成本身就是写代码的一个环节 

一句话总结:


前言:

  本篇博客内容来源自:极客时间课程《10x程序员工作法》处于学习记录。将个人认为比较重要的知识点进行摘抄记录。有兴趣的同学去极客时间学习完整课程。


 一、高效程序员的思考框架

思考框架:

  • 我现在是个什么水平?
  • 我想达到一个什么水平?
  • 我将怎样到达那个目标?

这三个问题实际上是帮我们确定:

  • 现状;
  • 目标;
  • 实现路径。

四个思考原则:

以终为始:

就是在工作的一开始就确定好自己的目标。我们需要看到的是真正的目标,而不是把别人交代给我们的工作当作目标。你可以看出这个原则是在帮助我们回答思考框架中,Where are we going?(我们要到哪儿去?)这个问题。

任务分解;

是将大目标拆分成一个一个可行的执行任务,工作分解得越细致,我们便越能更好地掌控工作,它是帮助我们回答思维框架中,How can we get there?(我们如何到达那里?)的问题。

沟通反馈;

是为了疏通与其他人交互的渠道。一方面,我们保证信息能够传达出去,减少因为理解偏差造成的工作疏漏;另一方面,也要保证我们能够准确接收外部信息,以免因为自我感觉良好,阻碍了进步。

自动化:

就是将繁琐的工作通过自动化的方式交给机器执行,这是我们程序员本职工作的一部分,我们擅长的是为其他人打造自动化的服务,但自己的工作却应用得不够,这也是我们工作中最值得优化的部分。

一句话总结:

 面对问题时,用思考框架问问自己,现状、目标和路径。


二、 以终为始:如何让你的努力不白费?

  1. 我们习以为常的思维模式是线性而顺序的,第一步做完,做第二步;第二步做完,做第三步。
  2. 以终为始的方式,不仅仅可以帮我们规划工作,还可以帮我们发现工作中的问题。
  3. 践行以终为始就是在做事之前,先考虑结果,根据结果来确定要做的事情。
  4. 以终为始的思维可以帮助我们更好地规划我们手头任务,也可以帮助我们发现过程中的问题。

一句话总结:

 遇到事情,倒着想。


三、 DoD的价值:你完成了工作,为什么他们还不满意?

DoD 是一个清单,清单是由一个个的检查项组成的,用来检查我们的工作完成情况。DoD 的检查项,就是我们开发产品所需的一系列有价值的活动。比如:编写代码、编写测试代码、通过测试人员验收等。什么样的活动是有价值的,也许每个团队的认识是不同的。但如果你的团队认为除了功能代码,其他都没价值,也许这是个信号,说明你的团队整体上是缺乏职业素养的,在这样的团队工作,前景并不乐观。

DoD 的检查项应该是实际可检查的。你说代码写好了,代码在哪里;你说测试覆盖率达标了,怎么看到;你说你功能做好了,演示一下。

DoD 是团队成员间彼此汇报的一种机制。别把汇报想复杂了,最简单的汇报就是说一句这个功能做完了。当我们有了 DoD,做事只有两种状态,即做完没做完。在团队协作中,我们经常会听到有人说这个事做完了 80%”,对不起,那叫没做完,根本没有 80% 做完的说法。

你应该知道,人与人协作,总会有这样或那样的理解差异。开始协作之前,我们最好先同步一下彼此的理解,确保之后不会因为理解不一致,而让协作方措手不及。怎样解决大家的理解偏差呢,我介绍了 DoD(完成的定义),它是行业中的一种最佳实践,能够在团队内部很好地同步大家对完成的理解。好的 DoD 是一个可以检查的清单,可以确保你不遗漏任何事情。

 一句话总结:

 在做任何事之前,先定义完成的标准。


四、 接到需求任务,你要先做哪件事?

     我们把以终为始的原则应用在需求领域中,就会注意到,用户故事有一个非常重要的组成部分是验收标准。

      验收标准不仅仅描述出了正常流程,也会关注到异常流程的处理,它也是我们验收测试用例的起点。一旦事先定义好验收标准,大量的扯皮工作就随之烟消云散了。

      理解了验收标准的作用,即便我们不使用用户故事来定义需求,依然可以把用户故事中的关键点应用到自己的实践中,在功能列表的每个功能定义中,增加验收标准。

一句话总结:

 在做任何需求或任务之前,先定好验收标准。


五、持续集成:集成本身就是写代码的一个环节 

写代码是程序员的职责,但我们更有义务交付一个可运行的软件。

如果想将每个程序员编写的代码很好地组合在一起,我们就必须做一件事:集成。

究竟要在开发后多久才进行一次集成呢?是半天、两个小时、还是一个小时呢?倘若这个想法推演到极致,是否就变成了只要有代码提交,就去做集成?

一个好的做法是尽早把代码和已有代码集成到一起,而不应该等着所有代码都开发完了,再去做提交。

一句话总结:

 尽早提交代码去集成。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
10x 程序员工作是一种高效、聚焦和快速迭代的工作方法论,旨在提高程序员工作效率和生产力。下面是对10x 程序员工作的简要回答: 1. 专注于高价值任务:10x 程序员专注于解决具有高价值和重要性的任务,避免浪费时间和精力在琐碎的工作上。 2. 学习新技术和工具:10x 程序员持续学习和掌握新的技术和工具,使自己保持在技术的最前沿,提高开发效率和解决问题的能力。 3. 自动化:10x 程序员善于使用自动化工具和脚本,通过自动化来减少手动操作和重复劳动,提高效率。 4. 代码质量和可维护性:10x 程序员注重编写高质量的代码,包括良好的命名、清晰的注释和可维护性,以减少代码维护的成本和问题的产生。 5. 持续集成和测试:10x 程序员将持续集成和测试作为开发流程的重要环节,通过自动化测试来保证代码的质量和稳定性。 6. 快速迭代和反馈:10x 程序员倡导快速迭代和及时反馈,通过快速开发、部署和用户反馈来不断改进产品和解决问题。 7. 团队合作和知识共享:10x 程序员懂得如何与团队成员合作和沟通,分享知识和经验,提高整个团队的效率和质量。 8. 注重性能和可扩展性:10x 程序员关注程序的性能和可扩展性,通过优化和调优来提高系统的性能和响应能力。 9. 持续改进和学习:10x 程序员思维开放,乐于接受新的挑战和反馈,不断改进和学习,提高自己的技术和职业能力。 10. 关注用户需求和体验:10x 程序员将用户需求和体验放在首位,注重产品的用户体验和价值,以用户满意度作为最终目标。 总而言之,10x 程序员工作强调高效、聚焦和快速迭代,通过专注于高价值任务、持续学习和改进、自动化和团队合作等方式,提高程序员工作效率和生产力。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值