标签类(tagged class)有着许多的缺点
破坏可读性
内存消耗
域不能做成final的
一句话:标签类过于冗长、容易出错、并且效率低下。
其实有更好的方法定义能表示多种风格对象的单个数据类型:子类型化(subtyping)。
标签类正是类层次的一种简单的仿效。
为了将标签类转变成类层次,首先要为标签类中的每个方法都定义一个包含抽象方法的抽象类,这每个方法的行为都依赖于标签值。
类层次纠正了前面提到过的标签类的所有缺点。每个类型的实现都配有自己的类,这些类都没有受到不相关的数据域的拖累。所有的域都是final的。编译器确保每个类的构造器都初始化它的数据域,对于根类中声明的每个抽象方法,都确保有一个实现。这样就杜绝了由于遗漏switch case 而导致运行时失败的可能性。多个程序员可以独立的扩展层次结构,并且不用访问根类的源代码就能相互操作。每种类型都有一种相关的独立的数据类型,允许程序员指明变量的类型,限制变量,并将参数输入到特殊的类型。
类层次的另一种好处在于,他们可以用来反映类型之间本质上的层次关系,有助于增强灵活性,并进行更好地编译时类型检查。
简而言之,标签类很少有适用的时候。当你想编写一个包含显式标签域的类时,应该考虑一下,这个标签是否可以被取消,这个类是否可以用类层次来代替。当你遇到一个包含标签域的现有类时,就要考虑将它重构到一个类层次结构中去。