我们可以重构这些方法吗?

时间:2011-04-19 03:13:37

标签: java methods refactoring coding-style

我的课程实现方法如下:

void methodOne() {
    try {
        getHelper().doActionOne();
    } catch ( Exception ex ) {
        throw new CustomException( ex );
    }
}

void methodTwo() {
    try {
        getHelper().doActionTwo();
    } catch ( Exception ex ) {
        throw new CustomException( ex );
    }
}

void methodThree() {
    try {
        getHelper().doActionThree();
    } catch ( Exception ex ) {
        throw new CustomException( ex );
    }
}


void methodFour;
void methodFive;
...

有更好的方法吗?这些代码让我感到不舒服。

修改 抱歉,不清楚的例子。我正在用Hibernate实现GenericDao类,真正的代码是这样的:

class GenericDaoImpl<T, PK> {

    PK create( T object ) {
        try {
           getSession().save( object );
        } catch( Exception ex ) {
           throw new DataAccessLayerException( ex );// wrap any exception to my exception
        }
    }

   T read( PK id ) {
       try {
           getSession().get( T.class, id );
       } catch ( Exception ex ) {
           throw new DataAccessLayerException( ex );
       }

   }

  void update( T object );
  void delete( T object );

}

3 个答案:

答案 0 :(得分:6)

只是一个基本的建议,但你可以将它重构成类似“命令模式”的东西。此模式允许您将某些功能封装到实现单个方法的类中。该类可以被实例化并传递到另一个要执行的类,而执行器类不必知道或关心它正在做什么,它只需要调用execute()。如果动作需要参数,则实现Command的类可以包括可以在构造函数中设置的字段/属性,也可以包含标准属性设置器。

创建一个这样的界面(我的Java生锈了,所以这可能不是100%有效的语法):

public interface Command
{
    public void execute();
}

public class ActionOne implements Command
{
    public void execute()
    {
        // do actionOne...
    }
}

public class ActionTwo implements Command
{
    public void execute()
    {
        // do actionTwo...
    }
}

// etc. for more actions

然后创建执行操作的类,调用代码只需要传入正确的Command实现类。

public class Executor
{

    public void executeCommand(Command command)
    {
        try
        {
            // Put any boilerplate code here (logging, auditing, etc.)
            command.execute();
        }
        catch (Exception ex)
        {
            // Put general error handling code here.  If you're just catching and rethrowing, consider not catching the Exception at this level.  If it's a checked exception, add a throws clause to the method.
            throw new CustomException();
        }
    }
}

答案 1 :(得分:1)

是的,您可以随时重构代码。唯一的问题是你是否要重构以使其变得更好或更糟。这段代码奇怪的提示是一个很好的提示,它可以做得更好。

这似乎是多态性的良好候选者。使用一个共享方法尝试五个不同的类,而不是五种不同的方法。界面将它们组合在一起。

public interface DoIt {
  public void doIt();
}

public class One implements DoIt {
  public void doIt() {
    // code which was previously in getHelper.doActionOne();
  }
}

public class Two implements DoIt {
  public void doIt() {
    // code which was previously in getHelper.doActionTwo();
  }
}

...

public class Five implements DoIt {
  public void doIt() {
    // code which was previously in getHelper.doActionFive();
  }
}

现在唯一的事情是为情境创建正确的类,并调用其doIt()方法。

答案 2 :(得分:0)

此工具由Spring Framework以及许多其他人提供。首先,它有一个特定的HibernateTemplate,它将每个特定于Hibernate的异常映射到未经检查的相关Spring异常。其次,它提供了一个AOP服务来在方法级别转换异常,因此您可以指定一次映射并在多个服务之间统一应用它们。

虽然我不会将Spring用于这一功能,但它对构建应用程序有很大的好处,而且我已经使用它多年了。