`
lihuaiyuan84
  • 浏览: 10428 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

[转载] 如何估算编程的时间

阅读更多

 

Programmer Time Translation Table

 

An experienced project manager I used to work with claimed that he took the programmers’ time estimates, multiplied by pi and converted to the next time magnitude to get the true number. 1 day converts to 3.14 weeks. He had learned the hard way that programmers are bad at estimating times. To get a more precise conversion, I’ve created a translation table for programmers’ time estimations, trying to narrow down where things go wrong.

Estimate The Programmer Thinks What the Programmer Forgot Actual Time
30 seconds There’s just a small change to the code to be done. I know exactly what to type and where. It takes 30 seconds to type. Time for starting the computer, the development environment and getting the right source. The time to build, test, check in and document the fix 1 hour
5 minutes It’s a minor thing, I just have to look up the exact syntax on google and fix it. It’s quite rare to find exactly the right information on the first try. Even if it is found, it probably needs some adjustments before it works. Add time for building, testing etc. 2 hours
1 hour I know how to do it, but it’s some code to write so it will take some time. 1 hour is too tight to have any margin for unforeseen problems. Something always fails. 2 hours
4 hours It’s some code to write, but I roughly know the step. I know the Wizzabanga module of our standard framework can do it, but I have to check the documentation on exactly how to call it. This is probably the only realistic estimation. It is large enough to have some margin for unexpected problems, while the task is still small enough to grasp. 4 hours
8 hours I first have to refactor the Balunga class into two, then I’ll add a call to the Wizzabanga code and finally add the new fields to the GUI There’s a lot of dependencies on the Balunga class from different parts of the system. About 40 different files have to be adjusted. The newly added field in the GUI has to be added in the database as well. 8 hours is too large to grasp completely. There will be more steps than the programmer thought of when estimating. 12-16 hours
2 days It’s really quite a lot to code. I have to add some new tables to the database, a GUI for those and then the logic to read and write data to the tables. 2 days of work is too large to overview for most developers. There will surely be things that are missed. Not just small things, but entire major pieces of functionality required will be forgotten during the estimation. 5 days
1 week Ouch… that’s a HUGE task. I don’t have a clue on how to do it, but I can’t say I don’t know. One week should be enough, I hope, I really hope, but I can’t ask for more or they’ll think I’m not competent enough. The task is way too large to get an understanding of for most programmers. It has to be sent back to an architect that can help splitting it in smaller parts and provide some direction how it should be solved. The architect might find a simple way to do it – or find that there’s a lot more work than expected. 2-20 days

Time estimation is hard. Every programmer has an interval where the estimations are realistic. Going below that interval means that the overhead (building, testing checking in code) was overlooked. Going above that interval means that the task is too large to overview.

For junior developers, the interval might even be non existing. They overlook the overhead while on the same time any non-trivial task is too large for them to overview. I’d say that an experienced developer should get anything between 0.5 hours and 24 hours right. Above 24 hours a breakdown is needed. It can be done in the head and then summed to 60 hours by the developer – but even someone experienced need to have manageable chunks to think of.

It is also important to understand that experience in programming is not the same as experience in estimation. A developer that’s not involved in the estimation process won’t get good at estimation. Also if actual time spent is never measured and compared to the estimates, there is no feedback to learn from.

Eventually, every programmer will have use for estimation skills. To prepare for that, decide when things are done for each task you take on. Then estimate the task before starting. Finally count the time spent and compare that to the estimate. Also compare what you actually had to do to your own definition of done. That way you’ll improve both your understanding of all the details involved in a task, as well as improve your estimation skills.

分享到:
评论

相关推荐

    常用设计编程工具 NOVEX切削数据估算.zip

    常用设计编程工具 NOVEX切削数据估算.zip常用设计编程工具 NOVEX切削数据估算.zip常用设计编程工具 NOVEX切削数据估算.zip常用设计编程工具 NOVEX切削数据估算.zip常用设计编程工具 NOVEX切削数据估算.zip常用设计...

    VisualC 实效编程 46 同步网络时间

    VisualC 实效编程 46 同步网络时间VisualC 实效编程 46 同步网络时间VisualC 实效编程 46 同步网络时间VisualC 实效编程 46 同步网络时间VisualC 实效编程 46 同步网络时间VisualC 实效编程 46 同步网络时间VisualC ...

    基于事件和时间触发嵌入式系统编程思想

    基于事件和时间触发嵌入式系统编程思想 在嵌入式系统编程中,基于事件和时间触发的编程思想是两种常见的编程结构。事件触发编程方式是基于中断的编程方式,通过中断来响应事件,而时间触发编程方式是基于时间的编程...

    基于深度学习的身高估算C++与C混合编程设计源码

    基于深度学习的身高估算C++与C混合编程设计源码项目是一套集成了计算机视觉和机器学习技术的软件解决方案,旨在通过图像处理技术来估算人物身高。该项目采用了C++与C语言的混合编程技术,这在当代软件开发中是一种...

    基于C语言编程的EKF算法在电池SOC估算中的应用研究,用C语言辩识的EKF算法,用于电池SOC估算 ,C语言; EKF算法; 电池SOC估算,C语言实现EKF算法的电池SOC估算

    基于C语言编程的EKF算法在电池SOC估算中的应用研究,是一个涉及算法编程实现、电池模型建立和实验数据校准的综合性课题。通过对EKF算法的深入研究和不断优化,结合电池模型的精确建模和实验数据的精细处理,可以有效...

    实用的软件系统开发成本估算法-软件成本管理(含例子).docx编程资料

    2. **技术独立性**:功能点估算法不受特定开发技术的影响,而代码行估算法则需考虑具体的编程语言和技术栈。 3. **用户视角**:功能点估算法是从用户的角度出发,更关注软件的功能而非技术实现细节。而代码行估算法...

    软件工程中改进分析编程算法的工作量估算

    本文探讨了一种改进的分析编程算法在软件工程工作量估算中的应用。通过与Karner模型的比较,该算法显示出约40%的性能提升,并证明了其在校准用例点方法中的可行性。实验采用最小绝对偏差和随机子采样交叉验证评估...

    juki 离线编程软件

    这一特性极大地提高了工作效率,因为它使得程序员可以在生产线上进行其他工作的同时,对编程任务进行预处理和调试,避免了设备的闲置时间。 软件的主要功能包括: 1. **元件库管理**:JUKI软件提供了丰富的元件库...

    松下PLC编程软件松下PLC编程软件

    3. **仿真功能**:软件内置的仿真环境可以模拟PLC的运行状态,帮助用户在实际部署前验证程序的正确性,减少现场调试的时间和成本。 4. **诊断与故障排查**:通过编程软件,工程师可以检查PLC的错误日志,定位故障源...

    C#经典编程-220例

    《C#经典编程-220例》是一本深度挖掘C#编程精髓的教程,它包含了大量的实例,旨在帮助读者全面掌握C#编程语言的核心概念和技术。这220个例子覆盖了C#编程的各个层面,从基础语法到高级特性,从控制流到面向对象编程...

    64位 微处理器系统编程和应用编程.part1 周明德编著 完整清晰版

    《64位 微处理器系统编程和应用编程》 周明德编著 完整清晰版 1 针对当前应用最广泛的两种64位处理器--Intel和AMD的四核处理器作为基础进行介绍分析,反映了当代微处理器的最新发展。 2 把Intel和AMD两种处理器综合...

    Visual C++网络编程案例实战.pdf

    《Visual C++网络编程案例实战》一书深入探讨了如何利用Visual C++及MFC类库进行网络编程,尤其强调了Windows Socket的应用。本书不仅覆盖了理论基础,还提供了丰富的实践案例,帮助读者掌握网络编程的核心技能。 #...

    串口通信编程大全

    这时我以前编制rs-232串口程序时收集的一些有关串口编程的硬件和软件技术资料,对于想学习串口编程的朋友比较实用的。里面讲述了有关串口的基本支持和用VB通信时的一些技巧和注意方法。声明:本资料来自互联网,版权...

    (完整版)ST语言编程手册.pdf

    ST语言,也称为结构化文本(ST),是一种高级编程语言,它基于文本,用于工业自动化和控制系统的编程。根据IEC61131-3标准,ST语言被广泛应用于可编程逻辑控制器(PLC)和其他工业设备中。PLCopen是一个全球性的行业协会...

    项目软件开发价格估算

    2. **技术难度**:不同的技术架构、编程语言和开发平台会直接影响开发时间和成本。例如,复杂的算法设计、高性能系统优化或跨平台开发可能增加难度,从而提高成本。 3. **团队配置**:开发团队的规模、技能水平和...

    基于C语言编程的EKF算法在电池SOC估算中的应用研究,基于C语言的电池SOC估算优化-嵌入式卡尔曼滤波(EKF)算法的实现,用C语言辩识的EKF算法,用于电池SOC估算 ,用C语言;辩识;EKF算

    为此,研究者们开发了多种估算方法,其中卡尔曼滤波(Kalman Filter, KF)算法及其变体——扩展卡尔曼滤波(Extended Kalman Filter, EKF)算法,在电池SOC估算中展现出了较高的准确性。 C语言作为传统且广泛使用的...

    UEFI原理和编程

    在编程方面,UEFI提供了丰富的接口供开发者使用,支持多种编程语言如C语言等,但通常使用C语言来编写UEFI程序。开发者可以在UEFI的基础上开发各种引导加载器、系统工具和驱动程序。 UEFI还允许开发者从操作系统中...

    数控车床编程100例

    数控车床编程100例

Global site tag (gtag.js) - Google Analytics