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 19:33 | Nová verze

    Byla vydána verze 1.78.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání na GitHubu. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    dnes 11:22 | Bezpečnostní upozornění

    Služba Dropbox Sign (původně HelloSign) pro elektronické podepisování smluv byla hacknuta.

    Ladislav Hagara | Komentářů: 2
    dnes 11:00 | Nová verze

    Byla vydána nová major verze 8.0 textového editoru GNU nano (Wikipedie). Podrobný přehled novinek a oprav v oznámení v diskusním listu info-nano nebo v souboru ChangeLog na Savannah. Volbou --modernbindings (-/) lze povolit "moderní" klávesové zkratky: ^C kopírování, ^V vložení, ^Z vrácení zpět, … Tato volba je aktivována také pokud binárka s nano nebo link na ni začíná písmenem "e".

    Ladislav Hagara | Komentářů: 3
    včera 23:22 | IT novinky

    Před 60 lety, 1. května 1964, byl představen programovací jazyk BASIC (Beginners' All-purpose Symbolic Instruction Code).

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

    Byla vydána nová verze 12.0 minimalistické linuxové distribuce (JeOS, Just enough Operating System) pro Kodi (dříve XBMC) a multimediálního centra LibreELEC (Libre Embedded Linux Entertainment Center). Jedná se o fork linuxové distribuce OpenELEC (Open Embedded Linux Entertainment Center). LibreELEC 12.0 přichází s Kodi 21.0 "Omega".

    Ladislav Hagara | Komentářů: 0
    včera 12:55 | Nová verze

    Microsoft vydal novou velkou aktualizaci 2404.23 v září 2019 pod licencí SIL Open Font License (OFL) zveřejněné rodiny písma Cascadia Code pro zobrazování textu v emulátorech terminálu a vývojových prostředích.

    Ladislav Hagara | Komentářů: 0
    včera 05:33 | Nová verze

    OpenTofu, tj. svobodný a otevřený fork Terraformu vzniknuvší jako reakce na přelicencování Terraformu z MPL na BSL (Business Source License) společností HashiCorp, bylo vydáno ve verzi 1.7.0. Přehled novinek v aktualizované dokumentaci. Vypíchnout lze State encryption.

    Ladislav Hagara | Komentářů: 0
    30.4. 23:55 | Humor

    Spouštět webový prohlížeč jenom kvůli nákupu kávy? Nestačí ssh? Stačí: ssh terminal.shop (𝕏).

    Ladislav Hagara | Komentářů: 14
    30.4. 18:11 | Nová verze

    Yocto Project byl vydán ve verzi 5.0. Její kódové jméno je Scarthgap. Yocto Project usnadňuje vývoj vestavěných (embedded) linuxových systémů na míru konkrétním zařízením. Cílem projektu je nabídnou vývojářům vše potřebné. Jedná se o projekt Linux Foundation.

    Ladislav Hagara | Komentářů: 0
    30.4. 17:56 | Nová verze

    Operační systém 9front, fork operačního systému Plan 9, byl vydán v nové verzi "do not install" (pdf). Více o 9front v FQA.

    Ladislav Hagara | Komentářů: 0
    Podle hypotézy Mrtvý Internet mj. tvoří většinu online interakcí boti.
     (14%)
     (29%)
     (43%)
     (14%)
    Celkem 14 hlasů
     Komentářů: 3, poslední dnes 19:48
    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.