Назад к вопросам
Middle
13
public class RefEx { public interface DocumentProcessor { void process(Document document); } public static class PdfProcessor implements DocumentProcessor { @Override public void process(Document document) { // Специфическая логика для обработки PDF } } public static class DocxProcessor implements DocumentProcessor { @Override public void process(Document document) { // Специфическая логика для обработки Word } } public static class XmlProcessor implements DocumentProcessor { @Override public void process(Document document) { // Специфическая логика для обработки XML } } public static class DocumentService { private final Map<DocumentType, DocumentProcessor> processors = Map.of( DocumentType.PDF, new PdfProcessor(), DocumentType.DOCX, new DocxProcessor(), DocumentType.XML, new XmlProcessor() ); public void process(Document[] documents) { for (Document doc : documents) { // Общая логика обработки документа processors.get(doc.type).process(doc); } } } }
Компании, где спрашивали
экзон
Ответ от нейросети
sobes.tech AI
В представленном коде реализован паттерн стратегия для обработки разных типов документов. Интерфейс DocumentProcessor определяет метод process, который реализуется в конкретных классах PdfProcessor, DocxProcessor и XmlProcessor.
Класс DocumentService содержит мапу, связывающую тип документа с соответствующим процессором. При вызове метода process для массива документов происходит вызов специфической логики обработки для каждого типа.
Такой подход позволяет легко расширять поддержку новых форматов, просто добавляя новые реализации DocumentProcessor и обновляя мапу в DocumentService.
Пример использования:
Document[] docs = {new Document(DocumentType.PDF), new Document(DocumentType.DOCX)};
DocumentService service = new DocumentService();
service.process(docs);
Это улучшает читаемость и поддерживаемость кода, избегая громоздких условных операторов.