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 10:44 | IT novinky

    Revolut nabídne neomezený mobilní tarif za 12,50 eur (312 Kč). Aktuálně startuje ve Velké Británii a Německu.

    Ladislav Hagara | Komentářů: 0
    dnes 09:55 | IT novinky

    Společnost Amazon miliardáře Jeffa Bezose vypustila na oběžnou dráhu první várku družic svého projektu Kuiper, který má z vesmíru poskytovat vysokorychlostní internetové připojení po celém světě a snažit se konkurovat nyní dominantnímu Starlinku nejbohatšího muže planety Elona Muska.

    Ladislav Hagara | Komentářů: 0
    dnes 09:33 | IT novinky

    Poslední aktualizací začal model GPT-4o uživatelům příliš podlézat. OpenAI jej tak vrátila k předchozí verzi.

    Ladislav Hagara | Komentářů: 0
    dnes 08:11 | Nová verze

    Google Chrome 136 byl prohlášen za stabilní. Nejnovější stabilní verze 136.0.7103.59 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 8 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.

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

    Homebrew (Wikipedie), správce balíčků pro macOS a od verze 2.0.0 také pro Linux, byl vydán ve verzi 4.5.0. Na stránce Homebrew Formulae lze procházet seznamem balíčků. K dispozici jsou také různé statistiky.

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

    Byl vydán Mozilla Firefox 138.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 138 je již k dispozici také na Flathubu a Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    včera 15:55 | Pozvánky

    Šestnáctý ročník ne-konference jOpenSpace se koná 3. – 5. října 2025 v Hotelu Antoň v Telči. Pro účast je potřeba vyplnit registrační formulář. Ne-konference neznamená, že se organizátorům nechce připravovat program, ale naopak dává prostor všem pozvaným, aby si program sami složili z toho nejzajímavějšího, čím se v poslední době zabývají nebo co je oslovilo. Obsah, který vytvářejí všichni účastníci, se skládá z desetiminutových

    … více »
    Zdenek H. | Komentářů: 2
    včera 15:44 | IT novinky Ladislav Hagara | Komentářů: 2
    včera 13:55 | Komunita

    Richard Stallman přednáší ve středu 7. května od 16:30 na Technické univerzitě v Liberci o vlivu technologií na svobodu. Přednáška je určená jak odborné tak laické veřejnosti.

    Ladislav Hagara | Komentářů: 10
    28.4. 23:33 | Nová verze

    Jean-Baptiste Mardelle se v příspěvku na blogu rozepsal o novinkám v nejnovější verzi 25.04.0 editoru videa Kdenlive (Wikipedie). Ke stažení také na Flathubu.

    Ladislav Hagara | Komentářů: 0
    Jaký filesystém primárně používáte?
     (58%)
     (1%)
     (9%)
     (21%)
     (4%)
     (1%)
     (2%)
     (0%)
     (1%)
     (3%)
    Celkem 486 hlasů
     Komentářů: 18, poslední 17.4. 12:41
    Rozcestník

    Návrat do budoucnosti v Pythonu

    18.4.2007 22:49 | Přečteno: 1243× | Dev/Tech/Gnu | Výběrový blog | poslední úprava: 18.4.2007 22:50

    Minule jsem psal o tom, jak jdou se zásobníkem v Pypy dělat psí kusy. Uvedený příklad byl ale jen taková onanie. Dnes tu mám opravdovější příklad. Jedná se o funkci fork() modulu _stackless. Co tahle funkce dělá? Inu přesně to, co její jmenovkyně z pravého Unixu, jen nevytvoří nový proces, ale korutinu (takové lehkotonážní vlákno, které nemá preempci a musí se přepínat explicitně). Funkce se tedy vrátí "dvakrát". Po vyvolání zůstane provádění v hlavní korutině a tato korutina dostane referenci na nově vytvořenou synovskou korutinu. V synovské korutině vrátí fork hodnotu None. K čemu je to dobré? Představte si, že zavoláte nějakou funkci a dostanete její návratovou hodnotu. Nějakou dobu s touto návratovou hodnotou počítáte, ale pak zjistíte, že tato návratová hodnota se vám nějak nehodí do krámu. Vyvoláte tedy výjimku a program se vrátí v čase až do volání inkriminované funkce a tato funkce se pokusí vám poskytnout lepší návratovou hodnotu. Sci-fi? Mrkněte na následující příklad.
    # this is pyfork.py
    from _stackless import fork, coroutine, clonable
    
    class Fail(Exception):
    	pass
    
    def zero_or_one():
    	subcoro = fork()
    	if subcoro is not None:
    		try:
    			subcoro.switch() # in the parent: run the child first
    		except Fail:
    			pass
    			
    		return 1   # then proceed with answer 1
    	else:
    		return 0   # in the child: answer 0
    
    def f():
    	num = zero_or_one();
    	
    	if num == 0:
    		print "zero is not good enough!"
    		raise Fail
    	
    	print "we got ONE: ", num
    
    def main():
    	#just because fork() is not enabled in main routine
    	coro = clonable()
    	coro.bind(f)
    	coro.switch()
    	print "Done"
    
    main()
    
    Funkce zero_or_one vrací nulu nebo jedničku. Řekněme, že se nám ve funkci f nula ani trochu nelíbí. Vyvoláme výjimku Fail nastane návrat do minulosti. (Mimochodem, BTTF a Michaela J. Foxe mám fakt rád.) Samotná funkce zero_or_one funguje následovně. Fork vytvoří novou korutinu a reference na ni se uloží do proměnné subcoro. Provádění pokračuje v hlavní korutině (taže následující podmínka se vyhodnotí jako True). Jenže pak následuje přepnutí na synovskou korutinu, a funkce nakonec vrátí nulu. Když se ve funkci f vyvolá výjimka, tak se propaguje až do místa, kde synovská korutina započala svůj běh (tedy subcoro.switch()). Synovská korutina de-facto končí a výjimka se propaguje až do rodičovské korutiny (tohle je asi největší magie). Tam je výjimka ošetřena a funkce vrátí jedničku.

    Demonstrace

    Aby tohle fungovalo, je potřeba Pypy přeložit do Céčka s následujícími parametry:
    $ python translate.py --stackless --gc=framework --batch targetpypystandalone.py
    
    Pak se to pustí příkazem
    $ ./pypy-c pyfork.py
    
    a vypíše
    zero is not good enough!
    we got ONE:  1
    Done
    
           

    Hodnocení: 80 %

            špatnédobré        

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

    Komentáře

    Vložit další komentář

    18.4.2007 23:46 Kyosuke | skóre: 28 | blog: nalady_v_modre
    Rozbalit Rozbalit vše Re: Návrat do budoucnosti v Pythonu
    Nebylo by „poněkud“ inteligentnější místo vyhození výjimky do jiného vlákna prostě zavolat kontinuaci, která existuje přesně kvůli tomuhle účelu?
    18.4.2007 23:49 paskma | skóre: 13 | blog: Paskmův blog
    Rozbalit Rozbalit vše Re: Návrat do budoucnosti v Pythonu
    Něco proti Unixu?-)

    Asi ano, ale tohle mi přišlo zábavnější.
    19.4.2007 10:40 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: Návrat do budoucnosti v Pythonu
    ona to vlastne kontinuace je... jenom ten stav zasobniku uklada jinak...
    Asi před rokem se dostali hackeři na servry Debianu a ukradli jim zdrojové kódy.
    19.4.2007 11:10 Kyosuke | skóre: 28 | blog: nalady_v_modre
    Rozbalit Rozbalit vše Re: Návrat do budoucnosti v Pythonu
    No je taková hodně explicitní. :-) Ale čím jsou odlehčenější, tím líp. :-)

    Založit nové vláknoNahoru

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