tldr公司;我的dailyrecorddatamanager类有代码味道吗?是“神课”吗?我该如何改进结构?
你好,
我正在和spring合作我的第一个项目。它将从马德里(我住的地方)政府网站获取covid-19数据,按地点组织,并通过api提供。
下面是我正在使用的json数据示例。
{
"codigo_geometria": "079603",
"municipio_distrito": "Madrid-Retiro",
"tasa_incidencia_acumulada_ultimos_14dias": 23.4668991007149,
"tasa_incidencia_acumulada_total": 1417.23308497532,
"casos_confirmados_totales": 1691,
"casos_confirmados_ultimos_14dias": 28,
"fecha_informe": "2020/07/01 09:00:00"
}
每个json对象都是特定日期和特定市政区的病例和感染率记录。
在获取数据之后,程序:解析它,过滤它,修剪/舍入一些属性,按位置Map它,使用它为每个位置创建一个对象(districtdata),并将位置districtdata对象写入monodb示例。
目前,我已经按照单一责任原则将流程中的每个步骤划分为不同的类。在链接的屏幕截图中可以看到:
intellij包结构截图
我的问题是我不知道如何将这些多个类链接在一起。
目前我有一个经理班,对我来说有点像上帝班:
@Service
public class DailyRecordDataManager implements DataManager {
private final Logger logger = LoggerFactory.getLogger(DailyRecordDataManager.class);
private final DailyRecordDataCollector<String> dataCollector;
private final DataVerifier<String> dataVerifier;
private final JsonParser<DailyRecord> dataParser;
private final DataFilter<List<DailyRecord>> dataFilter;
private final DataTrimmer<List<DailyRecord>> dataTrimmer;
private final DataSorter<List<DailyRecord>> dataSorter;
private final DataMapper<List<DailyRecord>> dataMapper;
private final DataTransformer dataTransformer;
private final DistrictDataService districtDataService;
public DailyRecordDataManager(DailyRecordDataCollector<String> collector,
DataVerifier<String> verifier,
JsonParser<DailyRecord> parser,
DataFilter<List<DailyRecord>> dataFilter,
DataTrimmer<List<DailyRecord>> dataTrimmer,
DataSorter<List<DailyRecord>> dataSorter,
DataMapper dataMapper,
DataTransformer dataConverter,
DistrictDataService districtDataService) {
this.dataCollector = collector;
this.dataVerifier = verifier;
this.dataParser = parser;
this.dataFilter = dataFilter;
this.dataTrimmer = dataTrimmer;
this.dataSorter = dataSorter;
this.dataMapper = dataMapper;
this.dataTransformer = dataConverter;
this.districtDataService = districtDataService;
}
@Override
public boolean newData() {
String data = dataCollector.collectData();
if (!dataVerifier.verifyData(data)) {
logger.debug("Data is not new.");
return false;
}
List<DailyRecord> parsedData = dataParser.parse(data);
if (parsedData.size() == 0) {
return false;
}
List<DailyRecord> filteredData = dataFilter.filter(parsedData);
List<DailyRecord> trimmedData = dataTrimmer.trim(filteredData);
List<DailyRecord> sortedData = dataSorter.sort(trimmedData);
Map<String, List<DailyRecord>> mappedData = dataMapper.map(sortedData);
List<DistrictData> convertedData = dataTransformer.transform(mappedData);
districtDataService.save(convertedData);
return true;
}
}
我还考虑过将所有涉及的类链接在一个注入依赖项的链中->这样每个类都有流程中的下一个类作为依赖项,并且,如果数据没有问题,在需要时调用链中的下一个类。
但是我也觉得一定有一个设计模式可以解决我的问题!
谢谢!
1条答案
按热度按时间ulydmbyx1#
如果有人发现了这个并且想知道我最终选择了什么样的管道模式。
它让我可以轻松地将我正在使用的所有单独的类组织到一个干净的工作流中。它还使过程的每个阶段都非常容易测试。以及管道类本身!
我强烈建议对java模式感兴趣的人阅读本文,这篇文章是我广泛使用的。