Форум программистов, компьютерный форум, киберфорум
Java
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
0 / 0 / 1
Регистрация: 16.10.2015
Сообщений: 29

Калькулятор используя паттерн проектирования Цепочка обязанностей (Chain of Responsibility)

13.11.2022, 11:50. Показов 1127. Ответов 1

Студворк — интернет-сервис помощи студентам
Всем привет, подскажите пожалуйста может кто в курсе как можно реализовать Калькулятор при помощи паттерна проектирования Цепочка обязанностей (Chain of Responsibility)? Потому что вообще никак не получается.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
13.11.2022, 11:50
Ответы с готовыми решениями:

Реализация паттерна проектирования цепочка обязаностей (chain of responsibility)
Привет. Есть небольшой набросок паттерна проектирования цепочки обязанностей, написан на JavaScript, и нужно его адаптировать на Java,...

Паттерн "Цепочка обязанностей"
Ребят, помогите пожалуйста!!!! Паттерн "Цепочка обязанностей" использован и реализован уже, на NetBeans работали, задача такая: есть газета...

цепочка обязанностей
Пытаюсь сделать паттерн цепочка обязанностей. Чо-то не компилируется. Вот такие ошибки: 1) no matching function for call to...

1
8 / 7 / 1
Регистрация: 10.04.2021
Сообщений: 20
27.11.2022, 13:07
Например так. Есть класс Calculator.java, который принимает введенный запрос. В нем есть цепочка классов, которые занимаются обработкой запроса в зависимости от того, какая операция выполняется.
Кликните здесь для просмотра всего текста

Main.java
Java
1
2
3
4
5
6
7
8
9
10
import java.util.Scanner;
 
public class Main {
    public static void main(String[] args) {
        Calculator calculator = new Calculator();
        Scanner sc = new Scanner(System.in);
        String inputLine = sc.nextLine();
        calculator.process(new Expression(inputLine));
    }
}


Кликните здесь для просмотра всего текста

Calculator.java
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
public class Calculator {
    Processor chain;
 
    public Calculator() {
        buildChain();
    }
 
    private void buildChain() {
        chain = new AdditionProcessor(new SubtractionProcessor(new MultiplicationProcessor(new DivisionProcessor(null))));
    }
 
    public void process(Expression request) {
        chain.process(request);
    }
}


Каждый из классов, обрабатывающих запрос, проверяет, его ли это операция. Если его, то вывести результат. Если не его -- передать запрос следующему обработчику.

Кликните здесь для просмотра всего текста

AdditionProcessor.java
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
public class AdditionProcessor extends Processor {
    public AdditionProcessor(Processor nextProcessor) {
        super(nextProcessor);
    }
 
    public void process(Expression request) {
        if (request.getOperation() == Operation.ADDITION) {
            double result = request.getA() + request.getB();
            System.out.println("Addition: " + request.getInput() + " = " + result);
        } else {
            super.process(request);
        }
    }
}


Кликните здесь для просмотра всего текста

SubtractionProcessor.java
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
class SubtractionProcessor extends Processor {
    public SubtractionProcessor(Processor nextProcessor) {
        super(nextProcessor);
    }
 
    public void process(Expression request) {
        if (request.getOperation() == Operation.SUBTRACTION) {
            double result = request.getA() - request.getB();
            System.out.println("Subtraction: " + request.getInput() + " = " + result);
        } else {
            super.process(request);
        }
    }
}


Кликните здесь для просмотра всего текста

MultiplicationProcessor.java
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
class MultiplicationProcessor extends Processor {
 
    public MultiplicationProcessor(Processor nextProcessor) {
        super(nextProcessor);
    }
 
    public void process(Expression request) {
        if (request.getOperation() == Operation.MULTIPLICATION) {
            double result = request.getA() * request.getB();
            System.out.println("Multiplication: " + request.getInput() + " = " + result);
        } else {
            super.process(request);
        }
    }
}


Если даже последний обработчик не понимает, с какой операцией он имеет дело, выводим соответствующее сообщение.
Кликните здесь для просмотра всего текста

DivisionProcessor.java
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
class DivisionProcessor extends Processor {
 
    public DivisionProcessor(Processor nextProcessor) {
        super(nextProcessor);
    }
 
    public void process(Expression request) {
        if (request.getOperation() == Operation.DIVISION) {
            if (request.getB() != 0) {
                double result = request.getA() / request.getB();
                System.out.println("Division: " + request.getInput() + " = " + result);
            } else {
                throw new IllegalArgumentException("Division by zero");
            }
        } else {
            System.out.println("Check that you entered a valid operation");
        }
    }
}


Все обработчики наследуются от класса Processor.
Кликните здесь для просмотра всего текста

Processor.java
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
public abstract class Processor {
    private Processor nextProcessor;
 
    public Processor(Processor nextProcessor) {
        this.nextProcessor = nextProcessor;
    }
 
    ;
 
    public void process(Expression request) {
        if (nextProcessor != null)
            nextProcessor.process(request);
    }
}


Вводимые выражения описываются в классе Expression.
Кликните здесь для просмотра всего текста

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
public class Expression {
    private double a;
    private double b;
    private Operation operation;
    private String input;
 
    public Expression(String input) {
        this.input = input;
        String[] partsOfExpression = input.split(" ");
        a = Double.parseDouble(partsOfExpression[0]);
        b = Double.parseDouble(partsOfExpression[2]);
 
        switch (partsOfExpression[1]) {
            case "+":
                operation = Operation.ADDITION;
                break;
            case "-":
                operation = Operation.SUBTRACTION;
                break;
            case "*":
                operation = Operation.MULTIPLICATION;
                break;
            case "/":
                operation = Operation.DIVISION;
                break;
        }
    }
 
    public double getB() {
        return b;
    }
 
    public Operation getOperation() {
        return operation;
    }
 
    public String getInput() {
        return input;
    }
 
    public double getA() {
        return a;
    }
}


Арифметические операции описываются в енуме Operation.
Кликните здесь для просмотра всего текста

Operation.java
Java
1
2
3
4
5
6
public enum Operation {
    ADDITION,
    SUBTRACTION,
    MULTIPLICATION,
    DIVISION
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
27.11.2022, 13:07
Помогаю со студенческими работами здесь

Незадача с паттерном Цепочка обязанностей
В общем задание такое. Реализовать сказку(колобок). Естественно не через cout . И с обязательным применением цепочки обязанности. У меня...

Написать консольный калькулятор используя паттерны проектирования
Нужно было написать калькулятор, который реализует стандартные операции "+,-,*,/". И выбрать какой-нить паттерн проектирования. Я...

Паттерн проектирования
Мне было выдано задание: В текстовом файле хранятся пары вида <Имя>=<Значение>, где <Имя> - это идентификатор; <Значение>...

Выбрать паттерн проектирования
Есть вот такое задание: "Разработать программное приложение, позволяющее проводить анализ алгоритмов нахождения обратных матриц....

Паттерн проектирования builder
Всем доброго времени суток! Изучаю JS и столкнулся с проблемой по паттерну проектирования builder. Есть следуещее задание: Реализовать...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru