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 17:11 | Pozvánky

    Od čtvrtka 30. 5. do soboty 1. 6. lze v Praze navštívit Veletrh vědy, tj. největší populárně naučnou akci v České republice, kterou každoročně od roku 2015 pořádá Akademie věd ČR. Vstup zdarma.

    Ladislav Hagara | Komentářů: 0
    dnes 14:11 | Komunita

    Canonical představil Ubuntu optimalizované pro jednodeskový počítač s RISC-V procesorem Milk-V Mars.

    Ladislav Hagara | Komentářů: 0
    včera 21:22 | Nová verze

    Armbian, tj. linuxová distribuce založená na Debianu a Ubuntu optimalizovaná pro jednodeskové počítače na platformě ARM a RISC-V, ke stažení ale také pro Intel a AMD, byl vydán ve verzi 24.5.1 Havier. Přehled novinek v Changelogu.

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

    Společnost xAI založena Elonem Muskem a stojící za AI LLM modelem Grok získala investici 6 miliard dolarů.

    Ladislav Hagara | Komentářů: 1
    včera 15:44 | IT novinky

    Finálový zápas mistrovství světa v ledním hokeji přinesl nový rekord NIX.CZ (𝕏): "Dosavadní absolutní maximum našeho propojovacího uzlu bylo překonáno v čase 21:10, kdy jsme při přenosu dat dosáhli 3,14 Tbps. Je třeba také doplnit, že po deváté hodině večerní byly na maximu i ostatní datové přenosy nesouvisející s hokejovým šampionátem".

    Ladislav Hagara | Komentářů: 3
    včera 15:11 | Pozvánky

    Přihlaste svou přednášku na další ročník konference LinuxDays, který proběhne 12. a 13. října na FIT ČVUT v pražských Dejvicích. CfP poběží do konce prázdnin, pak proběhne veřejné hlasování a výběr přednášek.

    Petr Krčmář | Komentářů: 0
    25.5. 19:00 | Zajímavý projekt

    Na crowdsourcingové platformě Crowd Supply byla spuštěna kampaň na podporu open source biometrického monitoru ve tvaru hodinek HealthyPi Move. Cena je 249 dolarů a plánovaný termín dodání listopad letošního roku.

    Ladislav Hagara | Komentářů: 13
    24.5. 22:22 | Upozornění Ladislav Hagara | Komentářů: 21
    24.5. 17:44 | Nová verze

    Firma Murena představila /e/OS verze 2.0. Jde o  alternativní sestavení Androidu bez aplikací Google. Mezi novinkami je podrobnější nastavení ochrany soukromí před sledováním aplikacemi. Murena prodává několik smartphonů s předinstalovaným /e/OS (Fairphone, repasovaný Google Pixel 5).

    Fluttershy, yay! | Komentářů: 0
    24.5. 14:33 | Zajímavý software

    Do 30. května lze v rámci akce Warhammer Skulls 2024 získat na Steamu zdarma hru Warhammer 40,000: Gladius - Relics of War.

    Ladislav Hagara | Komentářů: 1
    Podle hypotézy Mrtvý Internet mj. tvoří většinu online interakcí boti.
     (89%)
     (3%)
     (4%)
     (4%)
    Celkem 926 hlasů
     Komentářů: 16, poslední 14.5. 11:05
    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: 1386×
    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.