表驱动方法是编程中很常用的一种方法。它的主要用途是简化复杂的逻辑判断,使程序简洁易懂,可读性,可维护性都大大提高。
用表的时候最主要考虑的是如何去访问表,一般来说,可以专门写一个函数来访问表,这样即使以后要改,也很方便。访问表的方法包括直接访问,索引访问,阶梯式访问等等。
直接访问是最简单最常用的方法。把需要处理的情况都列在一个表中,哪种情况来了,直接调用就好了。复杂一点的情况涉及到要好好设计一个表,选什么样的内容写在表里。对这个,作者在书中给了一个很好的例子,Flexible-Message-Format Example,这里就不详细说了。
如果直接访问做不到,或者太浪费空间,效率太低等,接下来就要考虑索引访问或者阶梯式访问。索引的目的是把一个很大的表变成一个很小的便于查找的表。阶梯式访问是给一系列连续值分档。说白了这两者都是一种映射,把大量的值分类分档。
所以说来表驱动的原则是很简单的,难点是在如何设计出合适的表。对这一点此书中讲的不多,可以寻找其他的资源学习。
最后附上checklist:
Checklist: Table Driven Methods
- Have you considered table-driven methods as an alternative to complicated logic?
- Have you considered table-driven methods as an alternative to complicated inheritance structures?
- Have you considered storing the table's data externally and reading it at run time so that the data can be modified without changing code?
- If the table cannot be accessed directly via a straightforward array index (as in the Age example), have your put the access-key calculation into a routine rather than duplicating the index calculation in the code?