工具开发:勿以善小而不为
这可能是一个被大家忽略的话题。工具的开发,往往是软件开发过程中不可或缺的关键因素。它们往往涉及到程序数据的制作,而这又是一个复杂系统完成的必要前提。
谈起这个话题,其实更是一种倡议,希望我们能重视软件开发过程中的工具开发。
在项目开发过程中,做得好的项目,往往会在项目初期就设计好需要开发哪些工具,并且会组织开发这些工具。这本身并没有什么可说的。可是我们先来看看实际情况吧。
最近一段时间,我接触了这些工具的一些使用者。有几种典型情况,可能是我们设计者当初没有意识到的:
-
软件数据的生成完全依赖于这些工具,而这些工具却是工作的效率瓶颈。
-
工具使用者和工具开发者几乎隔离,因此针对工具的反馈和需求很难第一时间进行处理,甚至没有联系。
-
工具可能在项目解散后继续使用。这是很可能的,但这个时候工具的维护就变成了互相推诿的过程,谁也不愿意背上这些琐碎的维护任务。
-
工具中的设计或实现失误,往往是一些无法预计的工作流程出现的根结!
上面的任意一点,都足以让我们意识到工具开发中质量的重要性。可惜的是,我们不容易意识到这一点。
在工具开发的初期以及工具开始使用后,往往会有一些有关易用性的提议被否决,理由往往是因为项目太忙,以后再说。所以在这里我要说:勿以善小而不为!你的每一次小小的修改,对以后的工作将起到巨大的作用。
工具的质量保障非常重要,对于提出的质量反馈应该做到及时修改。更重要的是对于易用性的改进!并尽量考虑工具的自动化性、执行性能。这些相对来说更重要。毕竟,BUG在早期还是容易发现的,可是易用性、自动化、性能这三方面却不是那么容易改进的。这就要求我们的工具设计者能够尽量地考虑清除,在有条件的情况下,设计者应该尽量做到试用一下全过程。并且应该针对大数据量进行测试。
说到现在,除了对工具设计者的能力提出了要求之外,更是要求我们的设计者要有这个心。不光将软件设计的心放在系统软件上,也同样要放到我们自己使用的工具上。
一个小的善举,就是工作效率的大大提升。所以我要说,针对工具开发,勿以善小而不为啊!