重构三--重新组织数据(Encapsulate Collection)(3)--作法

重构三--重新组织数据(Encapsulate Collection)(3)--作法
  • 作法(Mechanics)
    • 加入[为群集添加(add),移除(remove)元素]的函数.
    • 将[用以保存群集]的值域初始化为一个空群集.
    • 编译.
    • 找出[群集设值函数]的所有调用者.你可以修改那个设值函数,让它使用上述新建立的[添加/移除元素]函数;也可以直接修改调用端,改让它们调用上述新建立的[添加/移除元素]函数.
        • ==>两种情况下需要用到[群集设值函数];(1)群集为空时;(2)准备将原有群集替换为另一个群集时.
        • ==>你或许会想运用Rename Method(273)为[群集设值函数]改名,从setXxx()改为initializeXxx()或replaceXxx().
    • 编译,测试.
    • 找出所有[通过取值函数(getter)获得群集并修改其内容]的函数.逐一修改这些函数,让它们改用[添加/移除](add/remove)函数.每次修改后,编译并测试.
    • 修改完上述所有[通过取值函数(getter)获得群集并修改群集内容]的函数后,修改取值函数自身,使它返回该群集的一个只读映件(read-only view).
        • ==>在Java 2中,你可以使用Collection.unmodifiableXxx()得到该集群的只读映件.
        • ==>在Java 1.1中,你应该返回群集的一份拷贝.
    • 编译,测试.
    • 找出取值函数(getter)的所有用户,从中找出应该存在于[群集之宿主对象(host object)]内的代码.运用Extract Method(110)和Move Method(142)将这些代码移到宿主对象去.
  • 如果你使用Java 2,那么本项重构到此为止.如果你使用Java 1.1,那么用户也许会喜欢使用枚举(enumeration).为了提供这个枚举,你应该这样做.
    • 修改现有取值函数(getter)的名字,然后添加一个新取值函数,使其返回一个枚举.找出旧取值函数的所有被使用点,将它们都改为使用新取值函数.
        • ==>如果这一步跨度太大,你可以先使用Rename Method(273)修改原取值函数的名称;再建立一个新取值函数用以返回枚举;最后再修改所有调用者,使其调用新取值函数.
    • 编译,测试.

你可能感兴趣的:(重构三--重新组织数据(Encapsulate Collection)(3)--作法)