Zdravim, prosim vas, aku kolekciu je vhodne pouzit ked chcem proste ukladat prvky ktore mouzu byt aj rovnake (podla equals resp. hashCode) ale mali by byt usporiadane podla metody compareTo ktora porovnava na zaklade inych datovych zloziek ako equals.
Napr. mam osobu ktoru identifikuje povedzme meno. ALe chcem ju ukladat do kolekcie ktora radi podla veku. Je mi jedno ze tam budem mat dvoch Jakubov, aj ze budu mat rovnaky vek, nepotrebujem si pamatat ktory je ktory. Neviem ci na to idem spravne, ci by nebolo vhodnejsie pouzit externy komparator. Na ukladnaie len osob kt. sa mozu opakovat pouzijem zrjme nieco co impementuje List. Ale neviem ako sa da ArrayList usporiadat, myslim ze je usporiadany podla indexov.
Fórum › Java
Nieco ako TreeSet s moznostou opakovania prvkov
Tak ja to vidim na rozhrani SortedMap (konkretne implementaci TreeMap ...jina stejne neni :)). Kde klic si zvolis a kolekce se porovnava bud pomoci compareTo primo v objektu (implementace rozhrani Comparable), nebo muzes podstrcit konstruktoru SortedMap(TreeMap) libovolny Comparator.
Jen tak pro informaci... objektu implementujes rozhrani Comparable jen pokud se to jevi jako jeho "prirozene razeni" objektu. Napr. Integer(objekt ne primitivni dat typ) je logicke ze se radi podle jeho hodnoty, Datum podle timestamp a podobne. U toho typu Osoba je to dost spekulativni... nekdo by rek ze defaultne by ho porovnaval podle Prijmeni->Jmena a druhy zas podle rodneho cisla. Kazdopadne pokud ti pripada ze hodlas pouzivat razeni, ktere se ti nejevi jako logicke pro ten dany objekt, tak obecne pouzijes Comparator namisto Comparable.
Přidej příspěvek
Ano, opravdu chci reagovat → zobrazí formulář pro přidání příspěvku
×Vložení zdrojáku
×Vložení obrázku
×Vložení videa
Uživatelé prohlížející si toto vlákno
Podobná vlákna
Ako docielit nieco ako dynamicku tabulku — založil Dee
Niečo ako Skype — založil delphak
Nieco ako shell32.dl — založil lolik
Niečo ako LightBox — založil Anonym
Moderátoři diskuze