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 02:11 | Nová verze

    Open source platforma Home Assistant (Demo, GitHub, Wikipedie) pro monitorování a řízení inteligentní domácnosti byla vydána v nové verzi 2025.7.

    Ladislav Hagara | Komentářů: 0
    dnes 01:44 | Nová verze

    Wayland byl vydán ve verzi 1.24.0. Jde o menší vydání po více než roce. Více funkcionality bývá přidáváno v průběžných vydáních Wayland Protocols.

    Fluttershy, yay! | Komentářů: 0
    včera 23:44 | Nová verze

    Textový editor Geany byl vydán ve verzi 2.1. Jde o udržovací vydání po bezmála dvou letech. Obsahuje drobná vylepšení vyhledávání, aktualizace podpory zvýrazňování syntaxe a dále převážně opravy chyb.

    Fluttershy, yay! | Komentářů: 0
    včera 19:44 | Komunita

    Byly zveřejněny videozáznamy, dostupné také s prezentacemi přímo z programu, a také fotogalerie z open source komunitní konference DevConf.CZ 2025 konané od 12. do 14. června v Brně.

    Ladislav Hagara | Komentářů: 0
    5.7. 20:22 | Zajímavý software

    Navigace se soukromím CoMaps postavena nad OpenStreetMap je nově k dispozici v Google Play, App Store i F-Droid. Jedná se o komunitní fork aplikace Organic Maps.

    Ladislav Hagara | Komentářů: 6
    4.7. 19:33 | Nová verze

    Vývojáři OpenMW (Wikipedie) oznámili vydání verze 0.49.0 této svobodné implementace enginu pro hru The Elder Scrolls III: Morrowind. Přehled novinek i s náhledy obrazovek v oznámení o vydání.

    Ladislav Hagara | Komentářů: 1
    4.7. 15:22 | IT novinky

    Masivní výpadek elektrického proudu zasáhl velkou část České republiky. Hasiči vyjížděli k většímu počtu lidí uvězněných ve výtazích. Výpadek se týkal zejména severozápadu republiky, dotkl se také Prahy, Středočeského nebo Královéhradeckého kraje. Ochromen byl provoz pražské MHD, linky metra se už podařilo obnovit. Výpadek proudu postihl osm rozvoden přenosové soustavy, pět z nich je nyní opět v provozu. Příčina problémů je však stále neznámá. Po 16. hodině zasedne Ústřední krizový štáb.

    Ladislav Hagara | Komentářů: 84
    4.7. 02:33 | Nová verze

    Po více než roce vývoje od vydání verze 5.40 byla vydána nová stabilní verze 5.42 programovacího jazyka Perl (Wikipedie). Do vývoje se zapojilo 64 vývojářů. Změněno bylo přibližně 280 tisíc řádků v 1 500 souborech. Přehled novinek a změn v podrobném seznamu.

    Ladislav Hagara | Komentářů: 7
    4.7. 01:33 | Nová verze

    Byla vydána nová stabilní verze 7.5 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 138. Přehled novinek i s náhledy v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    3.7. 16:33 | Zajímavý software

    Sniffnet je multiplatformní aplikace pro sledování internetového provozu. Ke stažení pro Windows, macOS i Linux. Jedná se o open source software. Zdrojové kódy v programovacím jazyce Rust jsou k dispozici na GitHubu. Vývoj je finančně podporován NLnet Foundation.

    Ladislav Hagara | Komentářů: 0
    Jaký je váš oblíbený skriptovací jazyk?
     (60%)
     (27%)
     (7%)
     (2%)
     (1%)
     (1%)
     (3%)
    Celkem 361 hlasů
     Komentářů: 16, poslední 8.6. 21:05
    Rozcestník

    Zásobník nadivoko

    12.4.2007 22:15 | Přečteno: 1440× | Dev/Tech/Gnu | Výběrový blog

    Minule jsem tu psal o Pypy, implementaci Pythonu v jazyce samém, a o neuvěřitelné flexibilitě, kterou tato hračka nabízí.

    Též jsem psal, že Pypy umí variaci na Stackless Python, tedy oprostění se od limitů systémového zásobníku. Rekurze omezená jen velikostí paměti je jen začátek. Program může explicitně manipulovat se svým zásobníkem. Je možné rozličným způsobem přepínat zásobníkové rámce funkcí atd. Následující kód mi hlava dost dlouho nebrala :-):

    from pypy.rlib.rstack import yield_current_frame_to_caller
    
    def g():
        print 2
        frametop_before_5 = yield_current_frame_to_caller()
        print 4
        frametop_before_7 = frametop_before_5.switch()
        print 6
        return frametop_before_7
    
    def f():
        print 1
        frametop_before_4 = g()
        print 3
        frametop_before_6 = frametop_before_4.switch()
        print 5
        frametop_after_return = frametop_before_6.switch()
        print 7
        assert frametop_after_return is None
    
    
    def entry_point(argv):
    	print "ahoj"
    	f()
    	return 0
     
    def target(*args):
    	return entry_point, None
    

    Tento program vypíše "ahoj" a pak čísla od 1 do 7 (uspořádaně). Jen je potřeba to přeložit Pypáckým translátorem do C. Ty výsledné divočiny se zásobníkym se provádějí až v céčku. Jenže v C byste si to asi netroufli naprogramovat, v Pythonu je to bezpečné :-).

    $ python translate.py --stackless --batch targetstack.py
    ...
    [translation] Done.
    $ ./targetstack-c
    ahoj
    1
    2
    3
    4
    5
    6
    7
    
    Přepínáním rámců to nekončí, je například možné vzít zásobník s běžícím výpočtem, zabalit a poslat dopočítat na jiný stroj - taková serializace říznutá kontinuací.        

    Hodnocení: 100 %

            špatnédobré        

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

    Komentáře

    Vložit další komentář

    12.4.2007 22:20 outsider
    Rozbalit Rozbalit vše Re: Zásobník nadivoko
    Jsem jedinej, kdo netusi, k cemu by to mohlo byt dobry? Umi to aspon uvarit kafe?
    12.4.2007 22:32 paskma | skóre: 13 | blog: Paskmův blog
    Rozbalit Rozbalit vše Re: Zásobník nadivoko
    No ty korutiny a zelená vlákna se hodí, když si chceš naprogramovat MMORPG (čti: statisíce vláken, které je potřeba migrovat mezi stroji).
    13.4.2007 08:13 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: Zásobník nadivoko
    Hmm a co takhle na to použít erlang a máš to odladěné bezmála 20 lety v průmyslovém nasazení.
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    13.4.2007 09:06 paskma | skóre: 13 | blog: Paskmův blog
    Rozbalit Rozbalit vše Re: Zásobník nadivoko
    Jo, erlang je sice robustní a masivní paralelismus zvládající, ale Python má tu výhodu, že je to obyčejný imperativní jazyk.
    13.4.2007 09:53 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: Zásobník nadivoko
    ... ale Python má tu výhodu, že je to obyčejný imperativní jazyk.
    A je to skutečně výhoda? V tom vidím jedinou výhodu, umí v tom kódit každej jouda.
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    13.4.2007 11:07 paskma | skóre: 13 | blog: Paskmův blog
    Rozbalit Rozbalit vše Re: Zásobník nadivoko
    V podstatě jo :-). Znám spousty chytrých lidí, co nemají s Pythonem problém, ale o Erlangu v životě neslyšeli. Ne že by se chytří lidi nedovedli Erlang naučit, ale zkus si podat inzerát, že hledáš makáče na Erlang...
    13.4.2007 12:38 Ladicek | skóre: 28 | blog: variace | Havlíčkův brod
    Rozbalit Rozbalit vše Re: Zásobník nadivoko
    No a pak existujou lidi jako valeon :-))
    Ještě na tom nejsem tak špatně, abych četl Viewegha.
    13.4.2007 11:01 podlesh | skóre: 38 | Freiburg im Breisgau
    Rozbalit Rozbalit vše Re: Zásobník nadivoko
    Ty děláš něco s MMORPG v takovém měřítku?
    13.4.2007 11:05 paskma | skóre: 13 | blog: Paskmův blog
    Rozbalit Rozbalit vše Re: Zásobník nadivoko
    Nop. Já se snažím vyrobit model-checker :-)
    12.4.2007 22:32 Ladicek | skóre: 28 | blog: variace | Havlíčkův brod
    Rozbalit Rozbalit vše Re: Zásobník nadivoko
    Nad tímhle kódem začínám chápat, proč někteří lidé považují texty markýze de Sade za umění…
    Ještě na tom nejsem tak špatně, abych četl Viewegha.
    12.4.2007 22:35 paskma | skóre: 13 | blog: Paskmův blog
    Rozbalit Rozbalit vše Re: Zásobník nadivoko
    Tak to si ještě počkej. Příště napíšu o fork() na úrovni Pythoňáckých korutin. S tím pak jde dělat takový nechutný backtracking, že si člověk připadá jako v Prologu. :-)
    13.4.2007 00:55 Messa | skóre: 39 | blog: Messa
    Rozbalit Rozbalit vše Re: Zásobník nadivoko
    No a odkaz na vygenerovaný Céčkový zdroják? :-)
    13.4.2007 08:59 paskma | skóre: 13 | blog: Paskmův blog
    Rozbalit Rozbalit vše Re: Zásobník nadivoko
    Céčkový zdroják nic moc, je to stavový automat vygenerovaný z grafové reprezentace...
    long pypy_g_slp_entry_point(struct pypy_list0 *l_argv_0) {
            bool_t l_v12; bool_t l_v16; bool_t l_v6; long l_v17; long l_v18;
            long l_v4; struct pypy_object0 *l_v3;
            struct pypy_object_vtable0 *l_v15; struct pypy_object_vtable0 *l_v2;
            struct pypy_object_vtable0 *l_v5;
    
        block0:
            l_v4 = pypy_g_entry_point(l_argv_0);
            l_v5 = (&pypy_g_ExcData)->ed_exc_type;
            l_v6 = (l_v5 == NULL);
            if (!l_v6) {
                    goto block3;
            }
            goto block1;
    
        block1:
            /* kept alive: l_argv_0 */ ;
            l_v18 = l_v4;
            goto block2;
    
        block2:
            RPY_DEBUG_RETURN();
            return l_v18;
    
        block3:
            l_v3 = (&pypy_g_ExcData)->ed_exc_value;
            l_v2 = (&pypy_g_ExcData)->ed_exc_type;
            (&pypy_g_ExcData)->ed_exc_value = ((struct pypy_object0 *) NULL);
            (&pypy_g_ExcData)->ed_exc_type = ((struct pypy_object_vtable0 *) NULL);
            /* kept alive: l_v3 */ ;
            /* kept alive: l_argv_0 */ ;
    
    
    13.4.2007 09:08 paskma | skóre: 13 | blog: Paskmův blog
    Rozbalit Rozbalit vše Re: Zásobník nadivoko
    BTW: Jediný důvod, proč je v Adě goto je ten, že by ho mohli ocenit generátory kódu :-)
    13.4.2007 08:18 Tom.š Ze.le.in | skóre: 21 | blog: tz
    Rozbalit Rozbalit vše Re: Zásobník nadivoko
    Výborně, je to jistě krok správným směrem. I když mi přijde zbytečné mluvit pořád o tom zásobníku. Pokud to má být konsistentní, tak by to mělo fungovat i když se f i g inlinují (i když nevím, jestli to v Pythonu jde) a žádný zásobník ve hře není (a, popravdě řečeno, bych od "sufficiently advanced" kompilátoru očekával, že to vystreamlinuje do print 1...print 7 během kompilace). Nebo to je opravdu implementačně závislé na manipulace se zásobníkem v C a s "pravými" kontinuacemi to nepracuje?
    13.4.2007 09:35 Kyosuke | skóre: 28 | blog: nalady_v_modre
    Rozbalit Rozbalit vše Re: Zásobník nadivoko
    Hmm, a co aspoň takhle ocenit, že si aspoň někdo po všech těch letech (kromě smalltalkerů a lisperů, samozřejmě :-)) všiml, že není třeba se omezovat na lineární zásobník? ;-)

    (Mimochodem, to mi připomíná...prosím Tě, jak že to děláš s Lispem ve Vimu? Pořád nějak nemůžu přijít na to, jak lidsky hackovat závorky v tom modálním zázraku. :-))
    13.4.2007 10:59 Tom.š Ze.le.in | skóre: 21 | blog: tz
    Rozbalit Rozbalit vše OT - lisp ve vimu

    Vždyť jsem to v první větě ocenil. A v seznamu chybí forthisti - ti se omezují na dva zásobníky :)

    Asi nadešel čas na coming out. Pro psaní v lispu jsem přešel na emacs... po tuctu let s vimem. Pořád to ještě bolí, a ostatní věci dělám ve vimu, ale je to schizofrenní. Slime je slime. Zkoušel jsem kde co - konfiguraci vimu, propojení clispu a vimu přes readline mapování kláves, různé doplňky (vim+ecl a slim-vim), viper, ale prostě to není ono.

    13.4.2007 11:27 Kyosuke | skóre: 28 | blog: nalady_v_modre
    Rozbalit Rozbalit vše Re: OT - lisp ve vimu
    Ksakru, a já se těšil, že mě konečně naučiš, jak že to efektivně děláš s Lispem ve Vimu a ono takhle. :-) Možná by to chtělo, až bude použitelný Climacs, v něm reimplementovat Vim - ale celý, ne jen nějakou náhražku. Já se přiznávám, že jsem taky schizofrenní. Nu což, co se dá dělat. :-)
    13.4.2007 12:18 deda.jabko | skóre: 23 | blog: blog co se jmenuje "každý den jinak" | za new york city dvakrát doleva a pak už se doptáte
    Rozbalit Rozbalit vše Re: Zásobník nadivoko
    huh, pekna prasarna... ale dokazu ocenit ty kouzla... i kdyz fakt se s tim lip pracuje, kdyz je to prirozeny konstrukt jazyka, nez kdyz se explicitne hrabe na zasobnik.... btw. v jave 7 se uvazuje o implementaci kontinuaci... takze takoveto pokusy na realnych jazycich nejsou vubec od cesty....
    Asi před rokem se dostali hackeři na servry Debianu a ukradli jim zdrojové kódy.
    13.4.2007 14:14 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: Zásobník nadivoko
    Teda, když to srovnám s tímhle v erlangu:
    -module(switch).
    -export([start/0]).
    -define(print(X), io:format("~p~n", [X])).
    -define(switch(X), X ! switch, receive switch -> ok end).
    
    g() ->
    	?print(2),
    	F = receive PID when is_pid(PID) -> PID end,
    	?switch(F),
    	?print(4),
    	?switch(F),
    	?print(6),
    	?switch(F).
    
    f() ->
    	?print(1),
    	G = spawn(fun g/0), G ! self(),
    	receive switch -> ok end,
    	?print(3),
    	?switch(G),
    	?print(5),
    	?switch(G),
    	?print(7),
    	G ! switch,
    	ok.
    
    start() ->
    	io:format("ahoj~n"),
    	f().
    Tak je to celkem nic moc ten python a to se to ještě musí přeložit a spustit jinak než obvykle, rozuměj taky zkompilovat. Přičemž zkompilovat v erlangu znamená:
    > c(switch).
    {ok,switch}
    > switch:start().
    ahoj
    1
    2
    3
    4
    5
    6
    7
    ok
    >
    
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    14.4.2007 11:04 paskma | skóre: 13 | blog: Paskmův blog
    Rozbalit Rozbalit vše Re: Zásobník nadivoko
    Hm, pěkné. Ale já jsem neříkal, že Python přináší něco unikárního. Kontinuace jsou ve funkcionálních jazycích normálka. Akorád že tohle je skoro-mainstreamový Python a navíc to jde přeložit do céčka.
    16.4.2007 08:23 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: Zásobník nadivoko
    ... Kontinuace jsou ve funkcionálních jazycích normálka. ...
    Na tom je vtipné, že v erlnagu kontinuace nejsou. Krom toho, kdykoliv narazím na problém s kontinuací, vždy bych se zamyslel, jestli to není chyba designu a nakonec je tu vždy možnost řešit to jako v erlangu thready, ale to musí být aspoň tak tenké jako v erlangu. V podstatě je to takový syntaktický cukr, akorát, že zatraceně sladký a i výkonostně jsou kontinuace trochu jinde než thready byť erlangovsky výkonné.
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    14.4.2007 10:54 Ondrej 'SanTiago' Zajicek
    Rozbalit Rozbalit vše Re: Zásobník nadivoko
    No a pomoci call-with-current-continuation se da docilit toho sameho a navic mnohem elegantnejsim zpusobem.

    Založit nové vláknoNahoru

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