abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 05:22 | Komunita

    Provoz Mozilla.social, tj. instance Mastodonu provozované Mozillou, bude 17. prosince 2024 ukončen.

    Ladislav Hagara | Komentářů: 0
    dnes 05:00 | Nová verze

    Byla vydána nová major verze 6 programovacího jazyka Swift (Wikipedie). Zdrojové kódy jsou k dispozici na GitHubu. Ke stažení jsou oficiální binární balíčky pro Ubuntu 20.04, Ubuntu 22.04, Ubuntu 24.04, Debian 12, Fedora 39, Amazon Linux 2 a Red Hat Universal Base Image 9.

    Ladislav Hagara | Komentářů: 0
    včera 19:00 | IT novinky

    Exploze osobních komunikačních zařízení v Libanonu zabily osm lidí, přibližně 2750 lidí je zraněno. Zhruba 200 jich je v kritickém stavu.

    Ladislav Hagara | Komentářů: 18
    včera 16:55 | Nová verze

    Byla vydána Java 23 / JDK 23. Nových vlastností (JEP - JDK Enhancement Proposal) je 12. Nová Java / JDK vychází každých 6 měsíců. LTS verze jsou 8, 11, 17 a 21 a bude 25.

    Ladislav Hagara | Komentářů: 1
    včera 16:22 | Nová verze

    Byla vydána betaverze Fedora Linuxu 41, tj. poslední zastávka před vydáním finální verze, která je naplánována na úterý 22. října. Z novinek (ChangeSet) lze vypíchnout Valkey místo nesvobodného Redisu, konec Pythonu 2, instalace proprietárních ovladačů Nvidia s podporou Secure Boot, DNF 5, RPM 4.20, KDE Plasma Mobile Spin, LXQt 2.0, …

    Ladislav Hagara | Komentářů: 1
    včera 13:11 | IT novinky

    Digitální a informační agentura (DIA) přebírá od 1. listopadu správu Registru obyvatel a Registru osob. Převodem pokračuje postupné soustřeďování sdílených informačních systémů státu pod DIA (𝕏).

    Ladislav Hagara | Komentářů: 3
    včera 13:00 | IT novinky

    Společnost Apple vydala nové verze operačních systémů pro svá zařízení: macOS 15 Sequoia, iPadOS 18, tvOS 18, visionOS 2, watchOS 11 a iOS 18.

    Ladislav Hagara | Komentářů: 7
    včera 01:22 | Komunita

    Konsorcium Linux Foundation představilo svůj nejnovější projekt s názvem OpenSearch Software Foundation zastřešující další vývoj OpenSearch a OpenSearch Dashboards. OpenSearch je forkem vyhledávače Elasticsearch a OpenSearch Dashboards je forkem souvisejícího nástroje pro vizualizaci dat Kibana. V roce 2021 přešly projekty Elasticsearch a Kibana z licence Apache 2.0 na duální licencování pod Server Side Public License (SSPL) a

    … více »
    Ladislav Hagara | Komentářů: 0
    16.9. 18:33 | Nová verze Ladislav Hagara | Komentářů: 0
    16.9. 12:55 | Zajímavý projekt

    TamaGo je open source framework pro programování ARM a RISC-V systémů na čipu (SoC) v programovacím jazyce Go. Prezentace projektu z OSFC (Open Source Firmware Conference) v pdf na GitHubu.

    Ladislav Hagara | Komentářů: 0
    Rozcestník

    Dotaz: Java zvětšení pole pomocí znovuvytvoření

    27.12.2009 18:01 jafaa
    Java zvětšení pole pomocí znovuvytvoření
    Přečteno: 1393×
    Potřeboval bych v javě zvětšit pole. Asi jediná možná cesta je znovuvytvořit ho, tzn. mojepole = new int[velikost]; Takhle to funguje, ale mám pocit že tím se neuvolní místo v paměti po starém poli. Jestli je to tak, jak mám to místo uvolnit?

    Řešení dotazu:


    Odpovědi

    27.12.2009 19:07 Jan Trávníček | skóre: 10 | blog: ehonza | Existuje
    Rozbalit Rozbalit vše Re: Java zvětšení pole pomocí znovuvytvoření
    Java používá garbage collector, díky tomu se sama stará o uvolnění paměti - nic není potřeba uvolňovat. Zvětšení pole v javě můžeš jedině přes inicializaci jiného a překopírování obsahu (třída Arrays poskytuje metody na kopírování). Pokud by si vyžadoval dynamickou velikost pole zkusil bych ArrayList nebo něco obdobného.
    To mess up a Linux box, you need to work at it; to mess up your Windows box, you just have to work on it.
    27.12.2009 19:41 kuka
    Rozbalit Rozbalit vše Re: Java zvětšení pole pomocí znovuvytvoření
    Jen doplnim, ze zminene metody v Arrays jsou az od verze 1.6, (nejen) ve starsich lze pouzit System.arraycopy().
    Řešení 1× (Jan Trávníček)
    28.12.2009 11:32 Filip Jirsák | skóre: 68 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Java zvětšení pole pomocí znovuvytvoření
    Staré pole se uvolní automaticky po té, co na něj nebude ukazovat žádný odkaz – v Javě se o uvolňování paměti stará garbage collector. Jinak pokud potřebujete měnit velikost, použijte raději nějakou kolekci. Používat pole a měnit jeho velikost může být dobré jedině v případě, kdy je to kritická část kódu, kterou potřebujete optimalizovat – a k tomu je zase potřeba Javu znát docela dobře. Pokud potřebujete výsledek předat někam, kde se očekává pole, převeďte kolekci na pole až těsně před použitím pomocí toArray().
    Řešení 1× (podlesh)
    28.12.2009 14:49 podlesh | skóre: 38 | Freiburg im Breisgau
    Rozbalit Rozbalit vše Re: Java zvětšení pole pomocí znovuvytvoření
    Jenom bych doplnil, že tazatel chce ukládat inty, takže používání standardních kolekcí (= boxing) přináší overhead (především paměťový). U malého objemu dat je to celkem jedno, ale u větších už je rozdíl znát a vyplatí se používat pole primitivních typů.

    I tak ale není nutné psát si to ručně, existují knihovny jako PCJ (mám dobré zkušenosti), GNU Trove (nemám zkušenosti) a řada dalších (nechce se mi hledat, google pomůže).
    28.12.2009 15:54 Filip Jirsák | skóre: 68 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Java zvětšení pole pomocí znovuvytvoření
    Přehlédl jsem, že jde o pole intů. Ale i tak, to co píšete už je optimalizace – a je lépe nejprve použít kolekce a teprve když se ukáže, že je tam výkonový nebo paměťový problém, řešit optimalizaci, než to psát rovnou „optimalizovaně“, nadělat chyby v kopírování polí, napsat to kopírování neefektivně a nakonec zjistit, že s tou optimalizací je to horší, než bez ní. Tedy nic proti optimalizacím, jenom je potřeba si uvědomit, že takové kopírování pole může ve skutečnosti výkon i paměťovou náročnost zhoršit. Ostatně, pro velký objem dat se zase bude spíš než pole hodit něco z java.nio.
    29.12.2009 12:52 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: Java zvětšení pole pomocí znovuvytvoření
    používanie javy všeobecne prináša pamäťový overhead :-)
    28.12.2009 18:21 maertien
    Rozbalit Rozbalit vše Re: Java zvětšení pole pomocí znovuvytvoření
    Diky Garbage Collector neni treba se uniku pameti obavat.
    28.12.2009 19:05 Filip Jirsák | skóre: 68 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Java zvětšení pole pomocí znovuvytvoření
    To bych netvrdil, i s garbage collectorem je možné vyrobit únik paměti. Není nutné explicitně uvolňovat paměť, ta se uvolní po té, co se daný objekt přestane používat (přestane na něj existovat ukazatel). Pořád ale můžete vyrobit únik paměti tak, že budete držet ukazatel na nějaký objekt, který už nepotřebujete.
    29.12.2009 12:55 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: Java zvětšení pole pomocí znovuvytvoření
    pozor, javovský gc pracuje len "niekedy v budúcnosti". Extrémna situácia: medzi dvoma spusteniami gc sa vyčerpá toľko pamäte, že gc jej nebude mať dosť na svoj vlastný beh :-)
    29.12.2009 13:25 Filip Jirsák | skóre: 68 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Java zvětšení pole pomocí znovuvytvoření
    Ze skutečnosti, že o tom nic nevíte, nemusíte hned vyvozovat závěr, že to určitě funguje špatně. Funkce alokátoru paměti nezávisí na tom, zda požadavky na alokaci paměti a její vrácení dostává explicitně od programátora, nebo se o ně stará nějaká softwarová komponenta.
    29.12.2009 13:41 podlesh | skóre: 38 | Freiburg im Breisgau
    Rozbalit Rozbalit vše Re: Java zvětšení pole pomocí znovuvytvoření
    Myslím že diskuse by se měla zamknout, jediné co zde přibude je flamewar.
    29.12.2009 16:45 cronin | skóre: 49
    Rozbalit Rozbalit vše Re: Java zvětšení pole pomocí znovuvytvoření
    To len hadas, alebo pises o nejakej prototypovej implementacii GC s cias ked JDK 1.0 bola horucou novinkou? Sucasne Javovske garbage collectory su uz uplne, ale uplne inde.

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.