【发布时间】:2021-08-20 22:44:02
【问题描述】:
我正在设计一个验证模块。它有 100 个错误代码(即 errcd_01、errcd_02、..、errcd_100)需要验证。在输入中,我得到一个高于 100 的特定错误代码(即 errcd_01)。 模块应该对特定的错误代码进行验证。
我正在使用工厂模式。
/* Interface */
public interface validateErrCd {
void check_errcd();
}
/* Concrete classes implementing the same interface */
public class validateErrCd_01 implements validateErrCd {
@Override
public void check_errcd() {
//business logic related to errcd_01
}
}
public class validateErrCd_02 implements validateErrCd {
@Override
public void check_errcd() {
//business logic related to errcd_02
}
}
.
.
.
public class validateErrCd_100 implements validateErrCd {
@Override
public void check_errcd() {
//business logic related to errcd_100
}
}
/* Factory */
public class ErrorValidationFactory {
//use check_errcd method to get object of type shape
public validateErrCd getValidation(String errorCode){
if(errorCode == null){
return null;
}
if(errorCode.equalsIgnoreCase("errcd_01")){
return new validateErrCd_01();
} else if(errorCode.equalsIgnoreCase("errcd_02")){
return new validateErrCd_02();
} ..
.......
else if(errorCode.equalsIgnoreCase("errcd_100")){
return new validateErrCd_100();
}
else {
return null;
}
}
}
/* I am using the Factory to get object of concrete class by passing an specific error code to be validated (i.e. "errcd_01"). */
public class FactoryPatternDemo {
public static void main(String[] args) {
ErrorValidationFactory errorFactory = new ErrorValidationFactory();
//get an object of validateErrCd_01 and call its check_errcd method.
validateErrCd errcd01 = errorFactory.getValidation("errcd_01");
//call check_errcd method of validateErrCd_01
errcd01.check_errcd();
}
}
现在由于 Factory 类 ErrorValidationFactory 中有多个 if/else,我在执行 mvn clean install 时遇到了几个 CI/CD 错误。 例如[MethodLength] - checkstyle, Rule:CyclomaticComplexity - PMD。
那么有没有一种方法可以替换工厂内部的 if/else、switch case 类型的决策,它不会在 Java 中触发上述 CI/CD 错误?
注意:如果可能的话,我想避免反思
【问题讨论】:
-
创建一个
Map<String, validateErrCd>并用validators.put("errcd_100", new validateErrCd_100())之类的条目填充它,然后.get()通过代码返回您的验证器。 -
@VLAZ 再三考虑,这是行不通的,因为使用相同键的 2 个调用将返回相同的实例,从他们显示的代码来看,这可能不是 OP 需要的(除非,也就是你在
getValidation里面创建地图) -
@FedericoklezCulloca 那么它只是一个
Map(String, Supplier<validateErrCd>)和validators.put("errcd_100", validateErrCd_100::new)对吧? -
@VLAZ 是的,这就是 dan1st answer(现在)所说的 :)
标签: java reflection factory checkstyle cyclomatic-complexity