干净的代码——Java静态函数和变量重用
我试图清理一个静态函数。让我在这里提供这个函数的模板。它是一个静态函数,仅在代码库中的两个位置使用,干净的代码——Java静态函数和变量重用,java,code-cleanup,Java,Code Cleanup,我试图清理一个静态函数。让我在这里提供这个函数的模板。它是一个静态函数,仅在代码库中的两个位置使用,isClient为true的位置和isClient为false的位置 public static void validate(BLangFunction resource, DiagnosticLog dlog, boolean resourceReturnsErrorOrNil, boolean isClient) {
isClient
为true
的位置和isClient
为false的位置
public static void validate(BLangFunction resource, DiagnosticLog dlog, boolean resourceReturnsErrorOrNil,
boolean isClient) {
if (!resourceReturnsErrorOrNil) {
dlog.logDiagnostic(Diagnostic.Kind.ERROR, resource.pos, "Invalid return type: expected error?");
}
switch (resource.getName().getValue()) {
case WebSocketConstants.RESOURCE_NAME_ON_OPEN:
case WebSocketConstants.RESOURCE_NAME_ON_IDLE_TIMEOUT:
validateOnOpenResource(resource, dlog, isClient);
break;
case WebSocketConstants.RESOURCE_NAME_ON_TEXT:
validateOnTextResource(resource, dlog, isClient);
break;
case WebSocketConstants.RESOURCE_NAME_ON_BINARY:
validateOnBinaryResource(resource, dlog, isClient);
break;
case WebSocketConstants.RESOURCE_NAME_ON_PING:
case WebSocketConstants.RESOURCE_NAME_ON_PONG:
validateOnPingPongResource(resource, dlog, isClient);
break;
case WebSocketConstants.RESOURCE_NAME_ON_CLOSE:
validateOnCloseResource(resource, dlog, isClient);
break;
case WebSocketConstants.RESOURCE_NAME_ON_ERROR:
validateOnErrorResource(resource, dlog, isClient);
break;
default:
dlog.logDiagnostic(Diagnostic.Kind.ERROR, resource.pos,
"Invalid resource name " + resource.getName().getValue() + " in service ");
}
}
此代码的问题在于dlog
变量与isClient
变量一起传递给所有其他调用函数。而ResourceReturnsErrorNil
仅在一个位置使用
我考虑过重构代码,使之具有非静态函数,以便dlog
可以是一个类变量,并且可以有两个类,一个用于客户端,另一个用于服务,所有公共代码都在一个超类中。然后我想这个函数只在两个地方使用,我们应该为它们设置实例类吗
可以找到此函数的源代码
基于干净代码原则进行重构的最佳方式是什么
然后我想这个函数只在两个地方使用,我们应该为它们设置实例类吗
这取决于你的目标。我同意,目前的准则远非理想。你概述的东西都有道理。因此,为了回答您的问题:是的,如果您认为这将有助于提高代码库的质量,那么拥有一个只在两个地方使用的“实例”类是非常好的
另一件需要仔细观察的事情是:也许有一种方法可以摆脱这个开关。例如,您可以使用一个映射(键:您的常量,值:一些函数接口…进行相应的验证) 该方法应为非静态。这样,您就可以将依赖项注入用于日志功能。为什么不保持原样呢?如果将其更改为类变量,则可能会有两个线程同时使用它,并且使用了错误的值。如上所述,问题是这不是一个非常干净的代码。我想改进一下。我不认为会有线程问题,因为我在这个应用程序中没有使用多个线程。你能解释解释解释的第二部分吗?我如何用地图消除开关?我想你是说对了?实际上,我也进行了重构,并发送了一个PR:)。谢谢