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.
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.
Canonical oznámil, že bude podporovat a distribuovat toolkit NVIDIA CUDA (Wikipedie) v Ubuntu.
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.
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.
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.
Spolek OpenAlt zve příznivce otevřených řešení a přístupu na 211. sraz, který proběhne v pátek 19. září od 18:00 ve Studentském klubu U Kachničky na Fakultě informačních technologií Vysokého učení technického na adrese Božetěchova 2/1. Na srazu proběhne přednáška Jiřího Eischmanna o nové verzi prostředí GNOME 49. Nemáte-li možnost se zúčastnit osobně, přednáškový blok bude opět streamován živě na server VHSky.cz a následně i zpřístupněn záznam.
Microsoft se vyhnul pokutě od Evropské komise za zneužívání svého dominantního postavení na trhu v souvislosti s aplikací Teams. S komisí se dohodl na závazcích, které slíbil splnit. Unijní exekutivě se nelíbilo, že firma svazuje svůj nástroj pro chatování a videohovory Teams se sadou kancelářských programů Office. Microsoft nyní slíbil jasné oddělení aplikace od kancelářských nástrojů, jako jsou Word, Excel a Outlook. Na Microsoft si
… více »Samba (Wikipedie), svobodná implementace SMB a Active Directory, byla vydána ve verzi 4.23.0. Počínaje verzí Samba 4.23 jsou unixová rozšíření SMB3 ve výchozím nastavení povolena. Přidána byla podpora SMB3 přes QUIC. Nová utilita smb_prometheus_endpoint exportuje metriky ve formátu Prometheus.
Správcovský tým repozitáře F-Droid pro Android sdílí doporučení, jak řešit žádosti o odstranění nelegálního obsahu. Základem je mít nastavené formální procesy, vyhrazenou e-mailovou adresu a být transparentní. Zdůrazňují také důležitost volby jurisdikce (F-Droid je v Nizozemsku).
Funkce vrací identifikační číslo objektu předaného v argumentu. Toto číslo je vlastně adresou, kde je objekt uložen v paměti. Většinou se bude jednat o celá čísla, ale může se jednat také o dlouhé celé číslo. Identifikační číslo objektu je naprosto originální. Zruší-li se však objekt, může být vytvořen nový se stejným číslem (na stejné adrese).
Obě tyto funkce slouží ke vstupu dat z klávesnice. Je-li zadán prompt, vytiskne se na standardní výstup ještě před čtením. raw_input přečte řetězec a vrátí jej tak, jak jej získal. Oproti tomu input pracuje jako následující příkaz: eval(raw_input(prompt)). Pro vstup od uživatele se tato funkce nehodí, není bezpečná. Není-li jí předán platný pythonský výraz, vyvolá výjimku SyntaxError. Může se stát, že budou vyvolány i jiné výjimky; to záleží na výrazu, který uživatel zadal. Pokud požadujete lepší funkcionalitu při uživatelském vstupu, můžete importovat modul readline - obě funkce jej automaticky použijí.
>>> raw_input("Zadejte jméno: ") Zadejte jméno: Jakub Matys 'Jakub Matys' >>> x = 25 >>> input() x ** 3 15625 >>> input() 'a' + 25 Traceback (most recent call last): File "", line 1, in ? File " ", line 0, in ? TypeError: cannot concatenate 'str' and 'int' objects >>>
Jediným úkolem této funkce je zjistit, zda je object instancí třídy classinfo. Pokud ano, vrací True, jinak False. Funkce může být také použita pro typovou kontrolu. Potřebujete-li kontrolovat, zda je objekt instancí určité množiny, můžete jako druhý argument předat n-tici tříd, typu, n-tic, nebo všeho dohromady.
>>> isinstance(5, float) False >>> class trida1: ... pass ... >>> class trida2 (trida1): ... pass ... >>> obj = trida2() >>> isinstance(obj, trida1) True >>> # jak je videt, polymorfismus funguje skvele >>> isinstance(5, (int, float, trida1)) True >>>
Další testovací funkce. Vrátí True, pokud je class podtřídou classinfo. Pravidla pro argumenty jsou stejná jako výše.
Tato funkce vrací mateřskou třídu typu type. Předáte-li jako druhý argument objekt, bude s ním vrácená třída provázána (tj. metody vrácené třídy budou volány pro objekt, jehož instance je předána jako druhý argument). Pokud je druhým argumentem objekt, musí platit isinstance(obj, type) == True. A pokud je druhý argument typ, je nutná podmínka issubclass(type2, type).
Následující příklad je docela jasný sám o sobě. (z Python.org)
class C(B): def meth(self, arg): super(C, self).meth(arg)
Funkce prochází seznam list a aplikuje na každou položku funkci function. Vrací seznam hodnot, které vrátila jednotlivá volání funkce function.
>>> def treti_moc(x): ... return x ** 3 ... >>> map (treti_moc, range(1,25)) [1, 8, 27, 64, 125, 216, 343, 512, 729, 1000, 1331, 1728, 2197, 2744, 3375, 4096, 4913, 5832, 6859, 8000, 9261, 10648, 12167, 13824] >>>
Funkce vrací objekt, který se používá pro řízený přístup k atributu třídy. Jako první tři argumenty se předávají funkce pro získání hodnoty atributu, funkce pro uložení do atributu a funkce pro smazání atributu. Posledním argumentem je dokumentační řetězec. V následujícím příkladě se ukládá do atributu __x pomocí x:
>>> class C(object): ... def __init__(self): self.__x = None ... def getx(self): return self.__x ... def setx(self, value): self.__x = value ... def delx(self): del self.__x ... x = property(getx, setx, delx, "I'm the 'x' property.") ... >>> obj = C() >>> obj.x = 7 >>> obj.x 7 >>> obj._C__x 7 >>>
Nástroje: Tisk bez diskuse
Tiskni
Sdílej:
>>> class trida1: ... pass ... >>> class trida2 (trida1): ... pass ... >>> obj = trida2() >>> isinstance(obj, trida1) True >>> # jak je videt, polymorfismus funguje skvele(
obj
je instancí trida2
, která dědí z trida1
, proto isinstance
vrací True
- tady to vidím já)
class A: def x(self): print "h" class B: def x(self): print "f" #a tady trochu "polymorfisujeme" A().x() B().x()
Polymorfismus – odkazovaný objekt se chová podle toho, jaký je jeho skutečný typ. Pokud několik objektů poskytuje stejné rozhraní, pracuje se s nimi stejným způsobem, ale jejich konkrétní chování se liší. V praxi se tato vlastnost projevuje např. tak, že na místo, kde je očekávána instance nějaké třídy, můžeme dosadit i instanci libovolné její podtřídy (třídy, která přímo či nepřímo z této třídy dědí), která se může chovat jinak, než by se chovala instance rodičovské třídy, ovšem v rámci mantinelů, daných popisem rozhraní.No a v tom mém příkladě máš 2 objekty, rozdílného skutečného typu, poskytující stejné rozhraní, s kterými se stejně pracuje, ale jejich konkrétní chování se liší. Ještě bych mírně dovysvětlil ten příklad s dědičností v té citaci. To je příklad spíše typický pro staticky typované jazyky, kdy se kompilátor, aby byl spokojenej, musí dozvědět, zda nějaké typy jsou kompatibilní (ve smyslu stejného rozhraní). A k tomu se dá využít dědičnost a nebo třeba v javě interfaces, které s dědičností vůbec nesouvisí. No a pokud ten jazyk nepoužívá statickou typovou kontrolu, tak to samozřejmě kompilátoru sdělovat nemusíš. Ale to neznamená, že v daném jazyce polymorfismus neexistuje. Prostě polymorfismus se statickou typovou kontrolou (nebo s dědičností) souvisí velmi vzdáleně.
"Polymorfismus objektu souvisí s definicí rozhraní a jeho zjednodušením. Je to známo také pod názvem přetížení objektu (funkce, metody, operátoru). Přesnější a jasnější definice polymorfismu je zde: http://www.cs.vsb.cz/saloun/educ/C_CPP/kurs_CPP/ch02s03.html Jeho podstata spočívá, že jeden název metody (funkce, operátoru) může sdílet několik metod, které se liší pčtem parametrů nebo jejich datovými typy. Jazyk pak sám podle předaných parametrů použije správnou. "Tak to si pleteš s ad-hoc polymorfismem, který je jen jednou z inkarnací polymorfismu obecně.
"To že Python podporuje prostory jmen a v nich může mít odkazy na funkce/metody/promenne stejneho nazvu neni polymorfismus."Ne, to polymorfismus není. Polymorfismus je schopnost jediné definice kódu pracovat s daty různých typů. To ale Python bezesporu (díky pozdní vazbě volání metod) umí, pokud dotyčný kód manipuluje se svými parametry prostřednictvím definovaných rozhraní.
S datovými typy polimorfismus souvisí dost úzce, viz první věta tvé citace.Však já netvrdím, že s datovými typy nesouvisí, ale tvrdím, že nesouvisí se statickou typovou kontrolou. No a zbytek viz Kyosuke. Ty si pod pojmem polymorfismus představuješ "overloading - přetěžování", což ti teda na základě wikipedie uznám jako jeden z typů polymorfismu, ikdyž stím moc niterně nesouhlasím
class A: def x(self): print "h" class B: def x(self): print "f" for z in [ A(), B()]: z.x()
x()
a druha treba yable jako y()
, pak objekt
co je obe splnuje, by byl IMHO kandidat na moznost uplatneni polymorfni chovani.
(Student nejsem, ale pripomina mi to trochu Freuda (viz. polymorfne perverzni chovani) pi = [kosočtverec, čárka] for elem in pi: elem.nakresli()Metoda nakresli() je jeden interface, který se pro různé typy postará o příslušnou akci.
a = 5 #celé číslo b = 5.2 #reálné číslo cisla = [a, b] for x in cisla: print x.__div__(2) #metoda vyděldvěma()Metoda vyděldvěma() udělá jinou akci pro integer (dělí celočíselně) a jinou akci pro float (dělí "reálně"). A je to polymorfismus, že jo? Velmi podobně by to vypadalo i v céčku, že? Jen s trochu jinou syntaxí. A co jaderné volání, které zjistí IP adresu síťovky? Je to polymorfismus, když pro různé síťovky (drátové i bezdrátové) od různých výrobců existuje jeden interface? A co funkce sinus? Je polymorfní, když na základě různých argumentů dělá různé akce a vrací různé výsledky? A co bitová negace? Kolik zrnek písku už je hromada?