Форум программистов, компьютерный форум, киберфорум
Java SE (J2SE)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.88/8: Рейтинг темы: голосов - 8, средняя оценка - 4.88
0 / 0 / 1
Регистрация: 28.03.2016
Сообщений: 24

Переопределение методов

12.10.2016, 18:10. Показов 1771. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть два метода, в которых одинаковое количество и тип аргументов, делают они почти одно и тоже, за исключением одной строки. Как сделать так, чтобы не нужно было переписывать кучу кода и создавать отдельный метод, чтоб изменить всего одну команду? Пытался сделать отдельный класс, наследуемый от того, в котором был первый метод, но получилось только вызвать метод суперкласса и дописать в него новый код, но не изменить старый. Есть какой-нибудь способ сделать то, что я задумал? Надеюсь, объяснил достаточно понятно.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
12.10.2016, 18:10
Ответы с готовыми решениями:

Переопределение методов
Здравствуйте. Изучать джаву начал неделю назад по книге "Файн Я. - Программирование на Java для детей, родителей, дедушек и бабушек -...

Переопределение методов
Помогите переопределить метод boolean equals ,hashCode() , toString() ? public class FileLab { private String name; ...

Переопределение методов в интерфейсе
Ребята подскажите пожалуйста, хочу разобраться. Проблема состоит в том, что у меня не получается переопределить методы которые прописаны в...

9
Диванный эксперт
Эксперт С++
 Аватар для Max Dark
2550 / 2064 / 971
Регистрация: 09.10.2013
Сообщений: 4,793
Записей в блоге: 4
12.10.2016, 18:21
justdude, так?
Java
1
2
3
4
5
6
7
8
9
10
11
12
class Base {
    public void method(int i) {
        System.out.println("Base");
    }
}
 
class A extends Base {
    public void method(int i) {
        super.method(i);
        System.out.println("A");
    }
}
0
3 / 3 / 4
Регистрация: 09.09.2014
Сообщений: 59
12.10.2016, 19:08
никак, компилятор выбирает тот метод, который подходит по аргументам. У тебя одинаковые аргументы.
0
Эксперт функциональных языков программированияЭксперт Java
 Аватар для korvin_
4575 / 2774 / 491
Регистрация: 28.04.2012
Сообщений: 8,779
12.10.2016, 20:20
Цитата Сообщение от justdude Посмотреть сообщение
Как сделать так, чтобы не нужно было … создавать отдельный метод
Не вижу причины вынести общий код в отдельный метод.

Цитата Сообщение от justdude Посмотреть сообщение
Надеюсь, объяснил достаточно понятно.
Нет, приведи пример кодом.
0
0 / 0 / 1
Регистрация: 28.03.2016
Сообщений: 24
12.10.2016, 21:27  [ТС]
korvin_, в данном фрагменте кода нужно поменять только строку с комментарием, тогда получится уже другой алгоритм поиска. Хотелось бы сделать это как-то по-умному, а не тупо копированием кода в отдельный метод.
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
    public boolean breadthSearch(ArrayList<GraphTop> ourTops, ArrayList<GraphTop> open, ArrayList<GraphTop> closed){
        output.enterNeededTop();
        GraphTop neededTop = null;
        int numOfNeededTop = input.inputInt();
        for (int l = 0; l< ourTops.size(); l++){
            if (ourTops.get(l).getNumOfTop() == numOfNeededTop){
                neededTop = ourTops.get(l);
                break;
            }
        }
        open.add(ourTops.get(0));
        while (!open.isEmpty()){
            GraphTop tempTop = open.get(0);
            System.out.println("Номер первой вершины " + tempTop.getNumOfTop());
            if (neededTop.equals(tempTop)){
                return true;
            }
            else {
                lists.deleteFirst(open);
                lists.addFirst(closed, tempTop);
                System.out.println("Номер вершины, добавленной в closed " + closed.get(0).getNumOfTop());
                int [] tempRelatedTops = tempTop.getRelatedTops();
                System.out.println("Количество смежных выбранной вершин " + tempRelatedTops.length);
                for (int j = 0; j<tempRelatedTops.length; j++){
                    System.out.println("Обрабатываемая смежная вершина " + tempRelatedTops[j]);
                    if (!lists.isContains(open,tempRelatedTops[j]) & (!lists.isContains(closed, tempRelatedTops[j]))){
                        for (int k = 0; k<ourTops.size(); k++){
                            GraphTop someTop = ourTops.get(k);
                            System.out.println("Номер вершины, которая будет сравниваться с номером смежной: "+ someTop.getNumOfTop());
                                if (someTop.getNumOfTop() == tempRelatedTops[j]){
                                    System.out.println("Номер вершины, совпавшей со смежной "+someTop.getNumOfTop());
                                    lists.addLast(open, someTop); /*Эта строка */
                                    break;
                                }
                            }
                        }
                    }
                }
            }
        open.clear();
        closed.clear();
        return false;
        }
0
Эксперт функциональных языков программированияЭксперт Java
 Аватар для korvin_
4575 / 2774 / 491
Регистрация: 28.04.2012
Сообщений: 8,779
12.10.2016, 21:50
Лучший ответ Сообщение было отмечено justdude как решение

Решение

justdude, что за lists? какого оно типа? Какая сигнатура у метода lists.addLast? Как поменять?

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
45
46
47
48
49
50
51
    public boolean breadthSearch1(ArrayList<GraphTop> ourTops, ArrayList<GraphTop> open, ArrayList<GraphTop> closed) {
        return breadthSearch(ourTops, open, closed, (lists, someTop) -> lists.addLast(open, someTop));
    }
 
    public boolean breadthSearch2(ArrayList<GraphTop> ourTops, ArrayList<GraphTop> open, ArrayList<GraphTop> closed) {
        return breadthSearch(ourTops, open, closed, (lists, someTop) -> lists.addFirst(open, someTop));
    }
 
    private boolean breadthSearch(ArrayList<GraphTop> ourTops, ArrayList<GraphTop> open, ArrayList<GraphTop> closed, BiConsumer<ArrayList<GraphTop>, GraphTop> adder) {
        output.enterNeededTop();
        GraphTop neededTop = null;
        int numOfNeededTop = input.inputInt();
        for (int l = 0; l< ourTops.size(); l++){
            if (ourTops.get(l).getNumOfTop() == numOfNeededTop){
                neededTop = ourTops.get(l);
                break;
            }
        }
        open.add(ourTops.get(0));
        while (!open.isEmpty()){
            GraphTop tempTop = open.get(0);
            System.out.println("Номер первой вершины " + tempTop.getNumOfTop());
            if (neededTop.equals(tempTop)){
                return true;
            }
            else {
                lists.deleteFirst(open);
                lists.addFirst(closed, tempTop);
                System.out.println("Номер вершины, добавленной в closed " + closed.get(0).getNumOfTop());
                int [] tempRelatedTops = tempTop.getRelatedTops();
                System.out.println("Количество смежных выбранной вершин " + tempRelatedTops.length);
                for (int j = 0; j<tempRelatedTops.length; j++){
                    System.out.println("Обрабатываемая смежная вершина " + tempRelatedTops[j]);
                    if (!lists.isContains(open,tempRelatedTops[j]) & (!lists.isContains(closed, tempRelatedTops[j]))){
                        for (int k = 0; k<ourTops.size(); k++){
                            GraphTop someTop = ourTops.get(k);
                            System.out.println("Номер вершины, которая будет сравниваться с номером смежной: "+ someTop.getNumOfTop());
                                if (someTop.getNumOfTop() == tempRelatedTops[j]){
                                    System.out.println("Номер вершины, совпавшей со смежной "+someTop.getNumOfTop());
                                    adder.accept(open, someTop); /*Эта строка */
                                    break;
                                }
                            }
                        }
                    }
                }
            }
        open.clear();
        closed.clear();
        return false;
    }
1
0 / 0 / 1
Регистрация: 28.03.2016
Сообщений: 24
12.10.2016, 22:12  [ТС]
korvin_, lists - это мой класс, в котором хранятся списки open, closed и список вершин графа. Так же там аксессоры для получения вышеперечисленных списков и методы для работы с вершинами графа. Вот листинг кода. Была идея написать условие, которое в зависимости от имени метода (breadthSearch или breadthSearch) вызывала бы соответствующий метод (addLast или addFirst), но я не нашел, как это реализовать. Различие в алгоритмах, как я писал ранее, только в вызове последнего метода. Пока идей нет, часть алгоритма, где задается вершина для сравнения, убрал в отдельный метод, чтоб выглядело все это дело более декомпозировано и не не так громоздко.
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
import java.util.ArrayList;
public class Lists {
    private ArrayList <GraphTop> ourTops;
    private ArrayList<GraphTop> open = new ArrayList<GraphTop>();
    private ArrayList<GraphTop> closed = new ArrayList<GraphTop>();
    public Lists(Graph graph){
        ourTops = new ArrayList<GraphTop>();
        this.ourTops.addAll(graph.getGraphTops());
    }
    public ArrayList<GraphTop> getOpen(){
        return open;
    }
    public ArrayList<GraphTop> getClosed(){
        return closed;
    }
    public ArrayList<GraphTop> getOurTops(){
        return ourTops;
    }
    public void deleteFirst(ArrayList<GraphTop> list){
        list.remove(0);
    }
    public void addFirst(ArrayList<GraphTop> list, GraphTop top){
        list.add(0, top );
    }
    public void addLast(ArrayList<GraphTop> list, GraphTop top){
        list.add(list.size(),top);
    }
    public boolean isContains(ArrayList<GraphTop> list, int j){
        boolean answer = false;
        for (int i = 0; i<list.size(); i++){
            GraphTop tempTop = list.get(i);
            if (tempTop.getNumOfTop() == j){
                answer = true;
            }
        }
        return answer;
    }
}
0
Эксперт функциональных языков программированияЭксперт Java
 Аватар для korvin_
4575 / 2774 / 491
Регистрация: 28.04.2012
Сообщений: 8,779
12.10.2016, 22:16
Цитата Сообщение от justdude Посмотреть сообщение
Пока идей нет
Я тебе подкинул идею, пользуйся наздоровье.
1
0 / 0 / 1
Регистрация: 28.03.2016
Сообщений: 24
12.10.2016, 22:24  [ТС]
korvin_, круто, спасибо! А как этот прием называется? Хотелось бы поподробнее про это узнать.
Java
1
2
3
4
5
6
 public boolean breadthSearch1(ArrayList<GraphTop> ourTops, ArrayList<GraphTop> open, ArrayList<GraphTop> closed) {
        return breadthSearch(ourTops, open, closed, (lists, someTop) -> lists.addLast(open, someTop));
    }
 
    public boolean breadthSearch2(ArrayList<GraphTop> ourTops, ArrayList<GraphTop> open, ArrayList<GraphTop> closed) {
        return breadthSearch(ourTops, open, closed, (lists, someTop) -> lists.addFirst(open, someTop));
0
Эксперт функциональных языков программированияЭксперт Java
 Аватар для korvin_
4575 / 2774 / 491
Регистрация: 28.04.2012
Сообщений: 8,779
12.10.2016, 22:27
Цитата Сообщение от justdude Посмотреть сообщение
А как этот прием называется?
Никак.

Цитата Сообщение от justdude Посмотреть сообщение
Хотелось бы поподробнее про это узнать.
http://www.oreilly.com/program... en_oo_v_fp
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
12.10.2016, 22:27
Помогаю со студенческими работами здесь

Переопределение абстрактных методов
Добрый день! Вопрос следующий: в подклассе необходимо переопределить абстрактный метод суперкласса, нужно сменить модификатор доступа с...

Переопределение методов, суперкласс, подкласс
package MyPack; class CorTriangle { double side; CorTriangle(double s) { side=s; } ...

Переопределение методов equals() и hashCode()
Дорогие форумчане, подскажите пожалуйста, как мне переопределить эти методы для моего класса? public class MyCollection implements...

Задача: Переопределение Методов (основы Java)
Задача : Как решить? Переопределение Методов Наш класс...

Наследование классов и переопределение методов из JDK
Чтобы грамотно переопределять методы нужно читать исходники или в доках есть достаточное количество информации? Если есть то можете...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru