Diskuze: Sortovani podle abecedy ArrayList obsahujici Objects
Člen
Zobrazeno 13 zpráv z 13.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
Skus implementovat Comparable<T> rozhraní.
Jak na to máš např. tady: http://stackoverflow.com/…s-comparable
pak tedy stačí zavolat Collections.sort(list); a pak stačí jen vypsat ve foreach např.
Diky za odpoved. Pokud jsem se spravne dival tak na tech strankach bud sortuji cely ArrayList bezohledu co obsahuje nebo ma jen jeden object takze jsem zatim nic nenasel . Ja mam object CD ktery ma supertridu(abstract) a ta supertrida ma dalsi supertridu a ta obsahuje tu informaci o title kterou potrebuji vysortovat. Kdyz budu sortovat cely ArrayList v te nejvyssi supertride tak me to maximalne ukaze dve subclasses ktere jsou ovsem supertridy pro CD nebo Knihy etc.
To Comparable implementuj v LibraryItem a pak ti půjde provést Collections.sort(itemsListItem).
Jak rikam ja to nikdy nedelal a pokud jsem si vsiml tak oni davaji Array do comparable a ne ArrayList.
I Give Up, Kdybych vedel jak to implementovat nebo udelat, tak se neptam tady ale podivam se na stejne odkazy na google. Kombinace veci co to tam vidim jsem nikdy nedelal takze mi to nic nerika. Nikdy jsem nic nesortoval podle fields ani v ArrayList . Prozatim jsem nikdy nepouzil ani comparable ani Collections.
Kazdopadne diky za vas cas.
Jde to udělat jednoduše. Tu třdu kterou chceš sortovat, tak implementuješ u ní rozhraní comparable<název_třídy>. To tě donutí implementovat funkci z rozhraní compareTo(nazev_tridy other). Poté si vyplníš podle čeho chceš porovnávat v dané funkci dva objekty dané třídy. Tedy něco ve smyslu
public class Trida implements comparable<Trida> {
public int x;
public int compareTo(Trida other) {
if(x > other.x)
return 1;
else if(x == other.x)
return 0;
else
return -1;
}
}
To je vše co musíš udělat. protože tvoje třída dědí z jiné, dostaneš se k Title bud jako třídní proměná nebo pomocí gettru (podle private/protected), no a uděláš to tak samo jak tady ten vzor, jen podle toho, jak chceš dva Title porovnat. To je vše
Ja myslel, ze musim pouzit nejaky loop pro ArrayList kde ty informace jsou
ulozene. Hlavni take je ze ja portebuji sortovat String napr
title = "Cesta z mesta"
title = "A ja do evropy" atd ktere jsou s dalsimi fields ulozeny v tom
arrayList
takze vysledek by byl podle abecedy title = "A ja do evropy" a pak title =
"Cesta z mesta"
Pokud potřebuješ nějaký loop není nic jednoduššího než použít nějaký třídící algoritmus, např. bubblesort http://www.algoritmy.net/…/Bubble-sort nebo jiný algoritmus. Pokud stačí čistě jen seřadit, využij toho compareTo a pošli to do metody Collections.sort(), která automaticky provede loop nad kolekcí a seřadí ji
Zobrazeno 13 zpráv z 13.