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 00:22 | Nová verze

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

    Ladislav Hagara | Komentářů: 0
    včera 20:33 | IT novinky

    Společnosti IBM a Red Hat představily Project Lightwell s investicí 5 miliard dolarů. Jedná se o důvěryhodné clearingové centrum pro bezpečnost open source softwaru a zabezpečení dodavatelských řetězců s novým AI modelem a globální skupinou více než 20 000 softwarových inženýrů. Služby centra budou dostupné prostřednictvím komerčních předplatných. Project Lightwell staví na iniciativách jako Anthropic Glasswing nebo OpenAI Trust Access for Cyber.

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

    Open source 3D herní a simulační engine Open 3D Engine (O3DE) byl vydán v nové verzi 26.05. Podrobný přehled novinek v poznámkách k vydání.

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

    Český stát by v budoucnu mohl provozovat vlastní alternativu ke komunikačním aplikacím typu WhatsApp, Signal, Telegram, Facebook Messenger a podobně. Cílem je zajistit bezpečnou datovou komunikaci pro stát a jeho důležité subjekty, jako jsou bezpečnostní složky, ministerstva a další organizace.

    Ladislav Hagara | Komentářů: 23
    včera 11:22 | Pozvánky

    Už za týden, ve čtvrtek 4. června, se v Národní technické knihovně v pražských Dejvicích uskuteční další konference věnovaná tématům spojeným s IPv6 - Den IPv6. Program akce a registrační formulář jsou k dispozici na webu akce. Kapacita konference je omezená, proto organizátoři doporučují, aby se vážní zájemci přihlásili včas (k dnešnímu dni zbývá přibližně 30 volných míst). Konferenci Den IPv6 2026 organizují i letos společně sdružení CESNET, CZ.NIC a NIX.CZ.

    VSladek | Komentářů: 1
    včera 05:22 | IT novinky

    Zařízení Steam Deck OLED bylo znovu naskladněno, ale vlivem rostoucích cen pamětí a úložišť má novou, vyšší cenovku. Steam Deck OLED 512 GB stojí nově 779 EUR (stál 569 EUR) a Steam Deck OLED 1 TB stojí 919 EUR (stál 679 EUR). Samotné zařízení se nijak nezměnilo a nové ceny tedy pouze odráží aktuální náklady na komponenty a další globální logistické výzvy, se kterými se potýká celá branže.

    Ladislav Hagara | Komentářů: 0
    27.5. 22:22 | IT novinky

    Český telekomunikační úřad zahajuje novou etapu využívání vysokofrekvenčního rádiového spektra v pásmu 26 GHz. Toto pásmo bude od 1. 7. 2026 otevřeno pro provoz moderních bezdrátových sítí, zejména sítí páté generace (5G), pevných bezdrátových přístupových sítí (FWA) a lokálních či průmyslových sítí určených například pro výrobní areály, logistická centra nebo technologické kampusy. Současně s otevřením pásma 26 GHz přistoupil ČTÚ ke zpřístupnění informací o využívání rádiových kmitočtů v tomto pásmu.

    Ladislav Hagara | Komentářů: 9
    27.5. 22:11 | IT novinky

    Logitech představil myš Signature Comfort Plus M850 L s polstrovanou opěrkou dlaně pro větší pohodlí a sadu s touto myší a klávesnicí s integrovanou opěrkou dlaní Signature Comfort Plus Combo MK880.

    Ladislav Hagara | Komentářů: 1
    27.5. 16:33 | IT novinky

    Gaël Duval se rozepsal o novinkách a plánech Murena a /e/OS. Počet uživatelů telefonů Murena a mobilního operačního systému /e/OS bez aplikací a služeb od Googlu se blíží 100 000. Ambicí je, aby se /e/OS stal třetí mobilní platformou v Evropě i na světě, s potenciálem dostat se i na PC. Blíží se vydání nové verze 4 s funkcemi zálohování a obnova, import e-mailů z Gmailu a rozpoznávání hlasu. Murena Workspace přinese videohovory, elektronický podpis a správu zařízení (MDM).

    Ladislav Hagara | Komentářů: 4
    27.5. 15:22 | Komunita

    Dnes a zítra probíhá Ubuntu Summit 26.04. Na programu je řada zajímavých přednášek. Sledovat je lze na YouTube. Úvodní slovo měli Mark Shuttleworth a Jon Seager.

    Ladislav Hagara | Komentářů: 1
    Které desktopové prostředí na Linuxu používáte?
     (12%)
     (8%)
     (2%)
     (14%)
     (31%)
     (4%)
     (6%)
     (3%)
     (16%)
     (26%)
    Celkem 1753 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Ant compile - z definice rozbité

    18.5.2009 22:36 | Přečteno: 1064× | Ani zbla

    V Javě jsem zvyklý využívat dobře definovaných class souborů. Myslím tím, že je možné nahradit v nějakém programu jeden class soubor jiným, za předpokladu že mají stejné rozhraní. Ono totiž ty class soubory jsou takové hezky deoptimalizované, všechny špinavé triky (inlinování atd.) dělá JVM až za běhu.

    Tato deoptimalizace má jednu velkou výjimku. Přišel jsem na to tak, že nefungoval "inkrementální" překlad v antu, tj. po zadání obligátního ant compile se program občas choval jinak než po ant rebuild.

    Pokud máte třídu

    public class Conf {
        public static final int DEBUG = 1;
    }

    tak třídy, které čtou konstantu DEBUG ji ve skutečnosti nečtou. Překladač do jejich těla s klidem vloží přímo literál, tedy jedničku. Takže když v Conf změníte hodnotu na DEBUG = 0 a znovu ji samu samotinkou přeložíte, změny se nepromítnou do jiných částí programu. Pomůže rebuild.

           

    Hodnocení: 100 %

            špatnédobré        

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

    Komentáře

    Vložit další komentář

    19.5.2009 00:14 petr_p | skóre: 59 | blog: pb
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité
    A to je vlastnost Antu nebo javac?
    alblaho avatar 19.5.2009 07:39 alblaho | skóre: 17 | blog: alblog
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité
    Javac kompiluje tak, že Ant není schopen přesně určit závislosti (on se dívá jenom na timestamp souboru).
    19.5.2009 11:04 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité
    To je vlastnost javac od Sunu od verze 1.5. A je to zdokumentovaná funkce, všichni (hm, skoro všichni) o ní vědí a vědí, že release projektu se dělá jako čistý build, nikdy jako výsledek inkrementální kompilace. Inkrementální kompilace je jenom pomůcka pro zrychlení vývoje (a třeba takový elcipse kompilátor dělá i horší věci, klidně přeloží soubor se syntaktickou chybou a příslušnou metodu s chybou nahradí pouze vyhozením výjimky, kde je zpráva o tom, že tam je syntaktická chyba).
    alblaho avatar 19.5.2009 13:38 alblaho | skóre: 17 | blog: alblog
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité
    Nikdo netvrdí, že to není zdokumentovaná vlastnost. Jenom jsem o tom nevěděl, to je celé. A o releasování projektu též nikdo nemluvil.
    mkoubik avatar 19.5.2009 00:25 mkoubik | skóre: 5 | blog: lorem_ipsum | Praha 8 - Bohnice
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité
    To jsi z toho vyvázl ještě dobře. Když podstrkuješ jiné .class soubory stejného názvu místo původních, aniž bys použil classloader, tak buď rád, že se ještě nesmažíš v pekle.
    alblaho avatar 19.5.2009 07:41 alblaho | skóre: 17 | blog: alblog
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité
    Můžeš to rozvést? Já ale nedělám takové věci u živé běžící aplikace (to obecně fungovat nemůže), prostě upravím a spustím.
    mkoubik avatar 19.5.2009 11:15 mkoubik | skóre: 5 | blog: lorem_ipsum | Praha 8 - Bohnice
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité
    Pokud napíšeš Conf c = new Conf();, tak kompilátor předpokládá, že třída Conf bude vždy vypadat tak, jak je popsána v Conf.java a všemožné optimalizace na to nejspíš spoléhají. Kdežto když použiješ Conf c = Class.forName("Conf").newInstance();, tak by to mělo fungovat, protože se třída hledá až v runtimeu (stejně tak by parametrem forName mohla být proměnná).

    Pokud tvrdíš, že třída Conf vypadá tak a tak a potom ji vyměníš, je to jako bys otevřel slinkovaný céčkový program v hexaeditoru a začal přepisovat části odpovídající nějakému objektu - taky radši použiješ shared object (.so).

    Skrátka třídy, které se navzájem "jůzujou" je lepší považovat za "slinkované", v prvním případě používáš přímo třídu Conf, v druhém pouze třídu java.lang.Class, která se, předpokládám, měnit nebude.

    A rada na závěr: na konfiguraci je XML.
    alblaho avatar 19.5.2009 13:42 alblaho | skóre: 17 | blog: alblog
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité
    Conf bude vždy vypadat tak, jak je popsána v Conf.java a všemožné optimalizace na to nejspíš spoléhají.

    Je právě otázka, jaké optimalizace se odehrají. Pokud je mi známo, je inlinování konstanty jediná výjimka, zbytek se děje až za běhu.

    PS: v mém projektíku si z různých důvodů nemůžu konfiguraci v XML dovolit :-)
    default avatar 19.5.2009 13:50 default | skóre: 22 | Madrid
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité
    PS: v mém projektíku si z různých důvodů nemůžu konfiguraci v XML dovolit :-)

    Tak použij -D parametry :-D

    19.5.2009 13:56 Ladicek | skóre: 28 | blog: variace | Havlíčkův brod
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité
    Proměnné prostředí se občas hodí. Ale jinak kód jsou data a data jsou kód a konfigurace v kódu je úplně v pořádku, pokud nepotřebuje uživatel dynamické změny. (A pokud je potřebuje, stačí použít skriptovací jazyk :-) )
    Ještě na tom nejsem tak špatně, abych četl Viewegha.
    default avatar 19.5.2009 13:58 default | skóre: 22 | Madrid
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité

    I tak bych to řešil properties souborem na ClassPath. Kvůli jedný blbině nemusíš zbytečně rekompilovat…

    mkoubik avatar 19.5.2009 14:06 mkoubik | skóre: 5 | blog: lorem_ipsum | Praha 8 - Bohnice
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité
    pokud nepotřebuje uživatel dynamické změny
    Což pravděpodobně potřebuje, když vyměňuje .class soubory. Teď nemyslím konkrétně tenhle případ - zapínání/vypínání debugování se takhle řešit dá, ale jak už tu zaznělo, je potřeba před produkčním nasazením celý projekt přebuildovat.
    alblaho avatar 19.5.2009 21:37 alblaho | skóre: 17 | blog: alblog
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité
    Konfigurace a vyměňování classů spolu nesouvisí. Párkrát jsem class vyměňoval a teď jsem (na příkladu s konfigurací) objevil případ, kdy to nefunguje, to je celé.
    default avatar 19.5.2009 14:06 default | skóre: 22 | Madrid
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité

    Co se té třídy Conf týče:

    zpravidla jsou tyto třídy javí interfaces, takže s nimi není třeba nikterak šachovat (když jo, tak se refaktoruje na obou stranách). A jak pak vypadá ta ConfImpl třída — to je už opravdu jedno. Jenom musí implementovat ten interface. Takhle třeba funguje vychytávka services.

    Docela se mi líbí ten princip modulů v NetBeans. Každý modul je rozdělen na dvě části (pozor, zjednodušuji!): první je public API (ty interfáče) a pak pod tím — ta druhá — je private API s implementací. Pomocí ClassLoaderů je zajištěno, že jiný modul se k té druhé části nedostane. Takže já pak můžu mít několik modulů, které implementují stejné veřejné API a implementace dělá něco trošku/úplně jiného. Je to v podstatě ten model services, akorát víc dotažený.

    19.5.2009 09:32 Ladicek | skóre: 28 | blog: variace | Havlíčkův brod
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité
    Já bych k tomu řekl jenom tolik: moje vývojové prostředí si závislosti hlídá :-)
    Ještě na tom nejsem tak špatně, abych četl Viewegha.
    alblaho avatar 19.5.2009 10:30 alblaho | skóre: 17 | blog: alblog
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité
    Hmm, že by bash nebyl tím nejlepším IDE?-).

    Chtělo by to nějaký plugin do anta. Jenomže když ant bude zkoumat každou třídu jestli tam něco takového není, to už může rovnou nechat přeložit všechno. IDE tohle zkoumání může dělat průběžně.
    default avatar 19.5.2009 10:09 default | skóre: 22 | Madrid
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité

    Sranda. Zrovna včera jsem na tenhle paskvil upozornil v naší aplikaci. :-D Konstanty obencě by neměly být public nebo package public. Od toho jsou enumy. (Pro rejpaly: neříkám, že to nejde nebo že se to nesmí. Ale zrovna debug level je učebnicová ukázka, jak se to používat nemá. :-) )

    Když není nazbyt, tak se to řeší takto:

    public static final String SOMETHING;
    
    static {
        SOMETHING = "foo";
    }

    Takto se vytvoří jen vazba na třídu (aspoň současná verze javac ten trik neumí odhalit) a inlinování provede až ClassLoader za běhu.

    Doporučuji si přečíst pár článků o modulárním programování v Javě. Toto konkrétně se řešilo před pár lety, když designovali GlassFish v3. Obecně o modulárním programování pojednává Jaroslav Tulach z NetBeans.

    Ale třeba o tom vím jen velký kulový. Koneckonců, v Javě jsem dělal naposledy před rokem. :-D

    19.5.2009 10:19 Ladicek | skóre: 28 | blog: variace | Havlíčkův brod
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité
    Jako člověk, který tomu ani trochu nerozumí a má tak patřičný odstup, pravím: modulární programování v Javě je jedna velká pakárna a ta classloaderová magie, kterou předvádí OSGi, je zralá akorát tak na cvokhaus. Zlatí chlapci od .NETu, v tohle.

    A dělat takovéhle triky s konstantami mi přijde padlé na hlavu. Pokud někdo tvrdí, že dělá inkrementální překlad, a přitom si nepohlídá závislosti, je to chucpe.
    Ještě na tom nejsem tak špatně, abych četl Viewegha.
    alblaho avatar 19.5.2009 10:35 alblaho | skóre: 17 | blog: alblog
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité
    Classloaderovou magii opravdu nemusím. Jak je to v .NETu ovšem netuším, umí vůbec nahrát dvě různé verze jedné assembly?

    Občas za běhu reloadnu nějaký modul v Pythonu, tam se na optimalizace kašle a všechno jede hezky dynamicky.

    default avatar 19.5.2009 13:56 default | skóre: 22 | Madrid
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité
    Classloaderovou magii opravdu nemusím.

    ClassLoadeři jsou mí nejlepší kamarádi. Ale já byl vždycky jinej. :-D Když si vzpomenu třeba na ResourceClassLoader, který natahoval aplikaci z resourců přímo z Jar archivu, takže jsem nemusel řešit takový ty lib/ adresáře a -cp parametry… Nebo můj miláček — EndorsedClassLoader. A endorsed.dirs šly tam, odkud přišly. :-D

    19.5.2009 14:01 Ladicek | skóre: 28 | blog: variace | Havlíčkův brod
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité
    takže jsem nemusel řešit takový ty lib/ adresáře a -cp parametry
    JarJar Links :-)
    Ještě na tom nejsem tak špatně, abych četl Viewegha.
    default avatar 19.5.2009 14:10 default | skóre: 22 | Madrid
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité

    No, až na to, že to ty knihovny přebalí a cosi to udělá s třídami — tak je to cool. Ale ten ClassLoader mi připadá trošku bezpečnější. :-D

    19.5.2009 14:12 Ladicek | skóre: 28 | blog: variace | Havlíčkův brod
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité
    Modifikace bajtkódu vládne světu. Sláva javovskému verifikátoru :-)
    Ještě na tom nejsem tak špatně, abych četl Viewegha.
    alblaho avatar 19.5.2009 10:32 alblaho | skóre: 17 | blog: alblog
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité
    Hm, dobrý workaround. Akorát je mi nesympatické psát složitější kód jenom proto, aby to javac nezoptimalizoval :-).
    mirec avatar 19.5.2009 11:12 mirec | skóre: 32 | blog: mirecove_dristy | Poprad
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité
    Určovať závislosti v jave je dosť ehm .. ako by som to správne nazval .. povedzme, že zložité. Minule som do školy riešil pár vecí a používal som vlastné makefile súbory, takže som si užíval to, že javac je neštandardný kompilátor snáď vo všetkom. U C som bol zvynutý na jednoduché generovanie hocičo.c -> hocičo.o pričom názov som si určoval sám. Z jedného súboru vždy práve jeden výstup. Javac to má výrazne zložitejšie pretože pri kompilácii niektorého súboru skompiluje automaticky aj všetky závislosti a ešte to aj pohádže do rôznych adresárov podľa balíčkov. Písať makefile pre toto je fakt peklo. Ale s dodržiavaním pár pravidiel a určením (nie všeobecných) pravidiel v makefile to bolo celkom ľahké a dovolím si tvrdiť, že som makefile napísal rýchlejšie než by mi nabootoval operačný systém netbeans.
    LinuxOS.sk | USE="-fotak -zbytocnosti -farebne_lcd +vydrz +odolnost +java" emerge telefon
    alblaho avatar 19.5.2009 13:33 alblaho | skóre: 17 | blog: alblog
    Rozbalit Rozbalit vše Re: Ant compile - z definice rozbité
    No zkrátka Java je dost jiná než C. Právě proto je lepší použít nástroje, které jsou jí šité na míru, třeba ten ant.

    Založit nové vláknoNahoru

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