abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 11:33 | Zajímavý článek Ladislav Hagara | Komentářů: 0
    včera 21:44 | Nová verze

    Byl vydán Mozilla Firefox 143.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Nově se Firefox při ukončování anonymního režimu zeptá, zda chcete smazat stažené soubory. Dialog pro povolení přístupu ke kameře zobrazuje náhled. Obzvláště užitečné při přepínání mezi více kamerami. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 143 bude brzy k dispozici také na Flathubu a Snapcraftu.

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

    Byla vydána betaverze Fedora Linuxu 43 (ChangeSet), tj. poslední zastávka před vydáním finální verze, která je naplánována na úterý 21. října.

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

    Multiplatformní emulátor terminálu Ghostty byl vydán ve verzi 1.2 (𝕏, Mastodon). Přehled novinek, vylepšení a nových efektů v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    včera 00:11 | Nová verze

    Byla vydána nová verze 4.5 (𝕏, Bluesky, Mastodon) multiplatformního open source herního enginu Godot (Wikipedie, GitHub). Přehled novinek i s náhledy v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    15.9. 21:33 | Nová verze

    Byla vydána verze 3.0 (Mastodon) nástroje pro záznam a sdílení terminálových sezení asciinema (GitHub). S novou verzí formátu záznamu asciicast v3, podporou live streamingu a především kompletním přepisem z Pythonu do Rustu.

    Ladislav Hagara | Komentářů: 0
    15.9. 21:00 | Komunita

    Canonical oznámil, že bude podporovat a distribuovat toolkit NVIDIA CUDA (Wikipedie) v Ubuntu.

    Ladislav Hagara | Komentářů: 0
    15.9. 20:44 | IT novinky

    Tržní hodnota americké společnosti Alphabet, která je majitelem internetového vyhledávače Google, dnes poprvé překonala hranici tří bilionů dolarů (62,1 bilionu Kč). Alphabet se připojil k malé skupině společností, které tuto hranici pokořily. Jsou mezi nimi zatím americké firmy Nvidia, Microsoft a Apple.

    Ladislav Hagara | Komentářů: 2
    15.9. 20:33 | IT novinky

    Spojené státy a Čína dosáhly dohody ohledně pokračování populární čínské platformy pro sdílení krátkých videí TikTok v USA. V příspěvku na síti Truth Social to dnes naznačil americký prezident Donald Trump. Dosažení rámcové dohody o TikToku vzápětí oznámil americký ministr financí Scott Bessent, který v Madridu jedná s čínskými představiteli o vzájemných obchodních vztazích mezi USA a Čínou. Bessentova slova později potvrdila také čínská strana.

    Ladislav Hagara | Komentářů: 0
    15.9. 16:55 | Komunita

    MKVToolNix, tj. sada nástrojů pro práci s formátem (medialnym kontajnerom) Matroska, byl vydán ve verzi 95.0. Podpora přehrávání formátu Matroska míří do Firefoxu [Bug 1422891, Technický popis]. Přehrávání lze již testovat ve Firefoxu Nightly.

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (67%)
     (100%)
     (0%)
     (0%)
     (0%)
     (0%)
     (33%)
     (0%)
     (0%)
    Celkem 3 hlasů
     Komentářů: 0
    Rozcestník

    Dotaz: Java - maximální velikost zásobníku a kompilátor Google Closure

    5.4.2013 16:49 Radek Miček | skóre: 23 | blog: radekm_blog
    Java - maximální velikost zásobníku a kompilátor Google Closure
    Přečteno: 388×
    Mám kód v JavaScriptu, jenž bych chtěl zmenšit a zjednodušit pomocí kompilátoru Google Closure (ten je napsaný v Javě).

    Bohužel Google Closure spadne na přetečení zásobníku. Zkoušel jsem tedy nastavit větší zásobník (pomocí parametru -Xss), ale to jde jen do velikosti 2 GB (-Xss2047M), což nestačí. Při pokusu o nastavení větší velikosti zásobníku (např. -Xss2048M) dostanu chybový výpis začínající:
    #
    # A fatal error has been detected by the Java Runtime Environment:
    #
    #  SIGSEGV (0xb) at pc=0x0000000000000000, pid=9351, tid=139969911744256
    #
    # JRE version: 7.0_17-b02
    # Java VM: OpenJDK 64-Bit Server VM (23.7-b01 mixed mode linux-amd64 compressed oops)
    
    Místo OpenJDK jsem zkoušel IKVM.NET, tam dostanu následující chybu:
    System.TypeLoadException: Could not load type 'com.google.javascript.jscomp.ComposeWarningsGuard' from assembly 'ikvm_dynamic_assembly__26728760, Version=2013.405.1736.22304, Culture=neutral, PublicKeyToken=null'.
    
    Otázka tedy je, jak spustit Javovský program, jenž potřebuje více než 2 GB zásobníku?

    Řešení dotazu:


    Odpovědi

    5.4.2013 17:32 Ivan
    Rozbalit Rozbalit vše Re: Java - maximální velikost zásobníku a kompilátor Google Closure
    2GB? Defaultni velikost zasobniku v JVM je 32MB. A temer na vsechno to staci. V Jave - narozdil od C++ - jsou vsechny objekty na heapu. Vsechny promenne jsou jen reference na heap a ty moc mista nezabiraji.

    Kdyz jsem kompiloval nejakou slozitou gramatiku pomoci ANTLR (ktery hojne vyuziva rekurzi) tak jsem musel zvednout velikost zasobniku na 128MB. Navic to bylo potreba jen na 32bit JVM. 64bit JVM si dokazala zasobnik zvetsit sama.

    Suma sumarum se domnivam, ze mas problem nekde jinde. Treba jsi objevil chybu v Google Closure kompilatoru anebo primo v OpenJDK.

    PS: na Linuxu zacina stack jednoho vlakna tam kde konci stack druheho. Aby si zacykleny vlakna navzajem neprepisovaly stack je mezi nimi jedna zamcena 4KB stranka. Kdyz na ni sahnes tak dostanes SEGV.

    5.4.2013 18:45 Radek Miček | skóre: 23 | blog: radekm_blog
    Rozbalit Rozbalit vše Re: Java - maximální velikost zásobníku a kompilátor Google Closure
    Díky za odpověď.
    Treba jsi objevil chybu v Google Closure kompilatoru
    Podobné skripty, ale menší (kolem 1-2 MB) se mi přeložit podařilo. Skript, jenž překládám teď, je větší (3,2 MB), ale v principu stejný, neboť je vygenerován stejným nástrojem.

    Problém pro Google Closure jsou možná delší funkce. Když v souboru ponechám pouze nejdelší funkci __IDR__.APPLY0, tak problém přetrvává - soubor má pouze 1,2 MB, a přesto dostanu java.lang.RuntimeException: java.lang.StackOverflowError.
    5.4.2013 21:57 Radek Miček | skóre: 23 | blog: radekm_blog
    Rozbalit Rozbalit vše Re: Java - maximální velikost zásobníku a kompilátor Google Closure
    Už jsem to vyřešil. Pomohli mi v diskuzní skupině kompilátoru Google Closure.

    Problém spočívá v tom, že velikost vlákna, v němž probíhá kompilace, je určena konstantou COMPILER_STACK_SIZE, tudíž nastavení -Xss nemá žádný vliv. Vyřešil jsem to tedy tak, že jsem si stáhl zdrojáky a změnil konstantu (v souboru src/com/google/javascript/jscomp/Compiler.java) z původní hodnoty 1 << 21 na novou hodnotu 1 << 27.

    Na závěr přikládám zdůvodnění, proč se konstanta používá:
    Under JRE 1.6, the JS Compiler overflows the stack when running on some large or complex JS code. When threads are available, we run all compile jobs on a separate thread with a larger stack.

    That way, we don't have to increase the stack size for every thread (which is what -Xss does).
    5.4.2013 17:35 Radek Miček | skóre: 23 | blog: radekm_blog
    Rozbalit Rozbalit vše Re: Java - maximální velikost zásobníku a kompilátor Google Closure
    Dodatek: Změřil jsem využití paměti a Google Closure využije zhruba 180 MB, než spadne na přetečení zásobníku. To znamená, že 2 GB se ani nevyužijí. Google Closure spouštím příkazem:
    java -Xss2047M -jar compiler.jar --js Vstup.js --js_output_file Vystup.js --language_in ECMASCRIPT5
    
    5.4.2013 17:42 Radek Miček | skóre: 23 | blog: radekm_blog
    Rozbalit Rozbalit vše Re: Java - maximální velikost zásobníku a kompilátor Google Closure
    Příloha:
    Přikládám skript - jedná se o soubor vygenerovaný kompilátorem jazyka Idris.

    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.