С Новым годом! Форум программистов, компьютерный форум, киберфорум
Java SE (J2SE)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.92/25: Рейтинг темы: голосов - 25, средняя оценка - 4.92
2 / 1 / 1
Регистрация: 18.12.2016
Сообщений: 26

Добавление экземпляра класса в список

08.10.2018, 10:34. Показов 4860. Ответов 18
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день, дорогие форумчане, мне дали задание :
Создать пользовательский класс с полем string, создать список и заполнить его экземплярами моего класса.
Вот как я решил это сделать:
Java
1
2
3
4
5
6
7
8
9
10
11
System.out.println("Введите 5 элементов коллекции:");
        TreeSet<MyCollection> stringTreeSet=new TreeSet<>();
        for(int i=0;i<5;i++){
            String str=in.nextLine();
            MyCollection myCollection=new MyCollection();
            myCollection.setStr(str);
            stringTreeSet.add(myCollection);
        }
        for(MyCollection str:stringTreeSet){
            System.out.print(str+" ");
        }
Но при выполнении получаю ошибку, скрин прилагается.
Искренне прошу помочь мне с решением этой проблемы)
Миниатюры
Добавление экземпляра класса в список  
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
08.10.2018, 10:34
Ответы с готовыми решениями:

Как при создании экземпляра класса инициализировать переменные вложенного класса
Здравствуйте. Подскажите пожалуйста как при создании екземпляра класа инициализировать переменные вложеного класа. Добавлено через 22...

Непонятный пример экземпляра класса
Что значит? Выходит на 36 строке. Сам код public class delegate { private interface Graphics { void draw(); }

Использование одного экземпляра класса
Добрый день! Помогите, никак не могу накопать нужную информацию. Как использовать один и тот же экземпляр класса, одну инстанту? В...

18
 Аватар для snajper_ro
116 / 101 / 52
Регистрация: 14.09.2011
Сообщений: 696
Записей в блоге: 1
08.10.2018, 10:47
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.*;
 
public class Main {
    /*
   Создать пользовательский класс с полем string, создать список и заполнить его экземплярами моего класса.
Вот как я решил это сделать:
 
     */
    public static void main(String[] args) {
 
        List<MyCl> list = new ArrayList<>();
        list.add(new MyCl(getRandomString(5)));
        list.add(new MyCl(getRandomString(6)));
        list.add(new MyCl(getRandomString(2)));
        list.forEach(System.out::println);
    }
    static class MyCl {
        public MyCl(String myField) {
            this.myField = myField;
        }
 
        @Override
        public String toString() {
            return "MyCl{" +
                    "myField='" + myField + '\'' +
                    '}';
        }
 
        String myField;
    }
    public static String getRandomString(int size) {
        StringBuilder b = new StringBuilder();
        Random r = new Random();
        for(int i =0; i < size; i ++)
            b.append((char)(r.nextInt(26) + 'a'));
        return b.toString();
    }
}
1)всегда надо весь код
2)трее сет это не лист
3)я бы вот так сделал
1
2 / 1 / 1
Регистрация: 18.12.2016
Сообщений: 26
08.10.2018, 11:04  [ТС]
Немного ошибся, мне нужно использовать множества, а не списки, поэтому и TreeSet а не List
0
614 / 488 / 175
Регистрация: 02.03.2010
Сообщений: 1,238
08.10.2018, 11:10
Лучший ответ Сообщение было отмечено Илья Лазарь как решение

Решение

Цитата Сообщение от Илья Лазарь Посмотреть сообщение
Мне нужно использовать множества, поэтому и TreeSet а не List
А почему не HashSet? Почему именно TreeSet?
Тоби ж красным по серому пишут, что не получается привести MyCollection к Comparable.
Сделай, что бы MyCollection реализовывал интерфейс java.lang.Comparable, ну и соответственно, его единственный метод compareTo, ошибка пропадет.
1
2 / 1 / 1
Регистрация: 18.12.2016
Сообщений: 26
08.10.2018, 11:51  [ТС]
Всё бы хорошо, но теперь появилась новая проблема - в множество заносится только один объект (первый).
0
614 / 488 / 175
Регистрация: 02.03.2010
Сообщений: 1,238
08.10.2018, 12:08
Что возвращает метод add, когда происходит попытка добавить 2й элемент?
1
2 / 1 / 1
Регистрация: 18.12.2016
Сообщений: 26
08.10.2018, 12:22  [ТС]
Да ничего, и ошибок никаких не бросает
Java
1
2
3
4
5
6
7
8
9
10
  TreeSet<MyCollection> myCollectionTreeSet = new TreeSet<>();
        System.out.println("Введите 5 элементов множества: ");
        for (int i = 0; i < 5; i++) {
            String str = in.nextLine();
            myCollectionTreeSet.add(new MyCollection(str));
        }
        System.out.println("Размер множества: "+myCollectionTreeSet.size());
        for (MyCollection obj : myCollectionTreeSet) {
            System.out.print("Элементы множества: "+obj);
        }
Изображения
 
0
Эксперт функциональных языков программированияЭксперт Java
 Аватар для korvin_
4575 / 2773 / 491
Регистрация: 28.04.2012
Сообщений: 8,761
08.10.2018, 12:38
Цитата Сообщение от Илья Лазарь Посмотреть сообщение
в множество заносится только один объект (первый)
И как ты реализовал Comparable для MyCollection?

И ещё сгененрируй методы equals и hashCode с помощью IDE.
1
2 / 1 / 1
Регистрация: 18.12.2016
Сообщений: 26
08.10.2018, 12:48  [ТС]
Про Comparable понял, а вот зачем мне equals и hashCode?
Java
1
2
3
public int compareTo(Object o) {
        return 4;
    }
0
528 / 263 / 70
Регистрация: 11.12.2016
Сообщений: 1,223
08.10.2018, 12:53
Цитата Сообщение от Илья Лазарь Посмотреть сообщение
в множество заносится только один объект (первый).
В множество нельзя заносить одинаковые объекты. Чем ваши объекты отличаются?
Как выглядит equals() вашей коллекции, еще бы непомешало toString() сделать и пока не разберетесь создавать экземпляр коллекции не в аргументе, чтобы посмотреть,вывести на экран что там внутри.

Добавлено через 3 минуты
Цитата Сообщение от Илья Лазарь Посмотреть сообщение
зачем мне equals и hashCode?
одинаковые объекты немогут быть в одном множестве.
грубо говоря : equals - сравнить, hashCode - отличать.
1
614 / 488 / 175
Регистрация: 02.03.2010
Сообщений: 1,238
08.10.2018, 13:03
Вообще, как бы я подумал про equals/hashCode, но, если они не переопределены, то будут работать стандартные механизмы, по крайней мере equals будет сравнивать ссылки, а ссылки разные. Да и хэш коды тоже...
Урааа, опять магия
1
2 / 1 / 1
Регистрация: 18.12.2016
Сообщений: 26
08.10.2018, 13:06  [ТС]
Огромное спасибо за помощь)
0
528 / 263 / 70
Регистрация: 11.12.2016
Сообщений: 1,223
08.10.2018, 13:21
_ViPeR_, я с вами согласен, да и сам же так думаю(мал), ведь TreeSet() конструкторы могут принимать как Collection() так и быть пустыми. Но есть один нюанс, TreeSet() расширяет SortedSet(), а он же не будет сортировать хэш?!
Потому я стараюсь перепроверять и вывести в консоль, хотя только один элемент и TreeSet() на это и наталкивают.
0
614 / 488 / 175
Регистрация: 02.03.2010
Сообщений: 1,238
08.10.2018, 13:26
Цитата Сообщение от ViktorFX Посмотреть сообщение
а он же не будет сортировать хэш?!
Зачем ему сортировать хэш?
0
528 / 263 / 70
Регистрация: 11.12.2016
Сообщений: 1,223
08.10.2018, 13:33
Цитата Сообщение от _ViPeR_ Посмотреть сообщение
Зачем ему сортировать хэш?
Потому что SortedSet() подразумевает что все элементы идут по нарастающей, а ему надо как-то сортировать, и если он бы сравнивал по ссылке, значит и сортировал бы тоже по ссылке.
0
614 / 488 / 175
Регистрация: 02.03.2010
Сообщений: 1,238
08.10.2018, 13:50
Цитата Сообщение от ViktorFX Посмотреть сообщение
Потому что SortedSet() подразумевает что все элементы идут по нарастающей, а ему надо как-то сортировать, и если он бы сравнивал по ссылке, значит и сортировал бы тоже по ссылке.
Не нужно путать функционал множества и сортированного множества. Сортированное множество - это, если грубо подходить, тоже самое множество, только элементы в нем сортируются. И для сортировки как раз используется метод compareTo,а вот как он будет реализован, уже никак не связано ни хэш-кодом, ни с equals. Можно, конечно использовать hashCode() в compareTo, но это бред.
А вот как раз функционал самого множества, которое предполагает, что все элементы в нем уникальные, как раз и использует методы для оценки уникальности, например HashSet - очевидно, что использует.
1
528 / 263 / 70
Регистрация: 11.12.2016
Сообщений: 1,223
08.10.2018, 14:54
_ViPeR_,
Я ошибался. Под "Нельзя добавлять одинаковые" я интуитивно понимал "одинаковые" как "эквивалентные" по equals().

Если кому интересно :
Имплементировал Comparable и переопределил equals(). В целях эксперимента делал неправильные equals() : (i == ((MyTree)o).getI() +10); - добавление работало нормально. А вот когда применил неправильный compareTo(), return this.i < o.getI()+10? -1 : this.i > o.getI()? 1 : 0; то начались добавлятся одинаковые значения.
Кликните здесь для просмотра всего текста
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
import java.util.*;
public class MyClass {
    public static void main(String args[]) {
        
        TreeSet<MyTree> tree = new TreeSet<>();
        MyTree a;
        a = new MyTree(1);
        System.out.println(tree.add(a)+" - "+a);
        a = new MyTree(2);
        System.out.println(tree.add(a)+" - "+a);
        a = new MyTree(2);
        System.out.println(tree.add(a)+" - "+a);
        a = new MyTree(3);
        System.out.println(tree.add(a)+" - "+a);
        a = new MyTree(4);
        System.out.println(tree.add(a)+" - "+a);
        a = new MyTree(3);
        System.out.println(tree.add(a)+" - "+a);
        a = new MyTree(1);
        System.out.println(tree.add(a)+" - "+a);
        a = new MyTree(2);
        System.out.println(tree.add(a)+" - "+a);
        a = new MyTree(5);
        System.out.println(tree.add(a)+" - "+a);
        a = new MyTree(7);
        System.out.println(tree.add(a)+" - "+a);
        for(MyTree t : tree) {
            System.out.println(t.getI());    
        }
    }
}
class MyTree implements Comparable<MyTree> {
    private int i;
    public int getI() {
        return i;
    }
    public MyTree(int i) {
        this.i = i;
    }
    @Override
    public int compareTo(MyTree o) {
        return this.i < o.getI()? -1 : this.i > o.getI()? 1 : 0;
    }
    @Override 
    public boolean equals(Object o) {
        return o instanceof MyTree &&
                (i == ((MyTree)o).getI() );
    }
}
0
2 / 1 / 1
Регистрация: 18.12.2016
Сообщений: 26
08.10.2018, 17:04  [ТС]
Народ, а как при выводе списка (List) через for, во время вывода третьего элемента вставить на вторую позицию новый элемент (или удалить элемент со второй позиции)?
0
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
08.10.2018, 17:46
Илья Лазарь, почитай про ListIterator
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
08.10.2018, 17:46
Помогаю со студенческими работами здесь

Использование одного экземпляра класса
Всем добрый день! Вот хоть убей, не могу понять как! Суть такая. Есть игра, в игре 4 класса, а именно. Main в котором идет игра....

OutOfMemoryError при создании экземпляра класса в цикле
Здравствуйте! У меня есть функция, реализующая поиск на отрезке методом дихотомии. Там используется цикл, где на каждой итерации создается...

Для чего null при создании экземпляра класса?
Добрый вечер! Вопрос следующий, во второй строке кода, а именно City biggestcity = null, зачем делать именно так и почему нельзя создать...

Объект класса - список объектов другого класса
Есть класс композиция, есть класс CD-диск. CD должен состоять из списка Композиций. Как после этого работать с CD как со списком? Может...

Добавление объекта класса
Подскажите, как добавить новый объект в класс? Есть форма, в которую пользователь вводит данные. Нужно как-то связать эту форму с...


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

Или воспользуйтесь поиском по форуму:
19
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru