Momo je fenka cavapoo, která svými náhodnými stisky kláves bezdrátové klávesnice vytváří jednoduché počítačové hry. Technicky to funguje tak, že Raspberry Pi s připojenou bluetooth klávesnicí posílá text do Claude Code, který pak v Godotu píše hry a sám je i testuje pomocí screenshotů a jednoduchých simulovaných vstupů. Za stisky kláves je Momo automaticky odměňována pamlsky. Klíčový je pro projekt prompt, který instruuje AI, aby i
… více »GNU awk (gawk), implementace specializovaného programovacího jazyka pro zpracování textu, byl vydán ve verzi 5.4.0. Jedná se o větší vydání po více než dvou letech. Mezi četnými změnami figuruje např. MinRX nově jako výchozí implementace pro regulární výrazy.
Internetový prohlížeč Ladybird ohlásil tranzici z programovacího jazyka C++ do Rustu. Přechod bude probíhat postupně a nové komponenty budou dočasně koexistovat se stávajícím C++ kódem. Pro urychlení práce bude použita umělá inteligence, při portování první komponenty prohlížeče, JavaScriptového enginu LibJS, bylo během dvou týdnů pomocí nástrojů Claude Code a Codex vygenerováno kolem 25 000 řádků kódu. Nejedná se o čistě autonomní vývoj pomocí agentů.
Byl vydán Mozilla Firefox 148.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Nově lze snadno povolit nebo zakázat jednotlivé AI funkce. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 148 bude brzy k dispozici také na Flathubu a Snapcraftu.
Byla vydána nová verze 22.1.0, tj. první stabilní verze z nové řady 22.1.x, překladačové infrastruktury LLVM (Wikipedie). Přehled novinek v poznámkách k vydání: LLVM, Clang, LLD, Extra Clang Tools a Libc++.
X86CSS je experimentální webový emulátor instrukční sady x86 napsaný výhradně v CSS, tedy bez JavaScriptu nebo dalších dynamických prvků. Stránka 'spouští' assemblerovový program mikroprocesoru 8086 a názorně tak demonstruje, že i prosté CSS může fungovat jako Turingovsky kompletní jazyk. Zdrojový kód projektu je na GitHubu.
Po šesti letech byla vydána nová verze 1.3 webového rozhraní ke gitovým repozitářům CGit.
Byla vydána nová verze 6.1 linuxové distribuce Lakka (Wikipedie), jež umožňuje transformovat podporované počítače v herní konzole. Nejnovější Lakka přichází s RetroArchem 1.22.2.
Matematický software GNU Octave byl vydán ve verzi 11.1.0. Podrobnosti v poznámkách k vydání. Vedle menších změn rozhraní jsou jako obvykle zahrnuta také výkonnostní vylepšení a zlepšení kompatibility s Matlabem.
Weston, referenční implementace kompozitoru pro Wayland, byl vydán ve verzi 15.0.0. Přehled novinek v příspěvku na blogu společnosti Collabora. Vypíchnout lze Lua shell umožňující psát správu oken v jazyce Lua.
public class SVG {
private static final SVG INSTANCE = new SVG();
private SVGGraphics2D svg;
private SVG() {
DOMImplementation domImpl =
GenericDOMImplementation.getDOMImplementation();
String svgNS = "http://www.w3.org/2000/svg";
Document document = domImpl.createDocument(svgNS, "svg", null);
svg = new SVGGraphics2D(document);
System.out.println("hello");
}
public static SVG getInstance() {
return INSTANCE;
}
public SVGGraphics2D getSVG() {
return svg;
}
}
Keď ale zavolám Graphics2D g2d = SVG.getInstance().getSVG(), dostanem null. Viete mi poradiť?
Řešení dotazu:
null dostával – můžete z jednoho vlákna volat getSVG() dřív, než v druhém vlákně doběhne konstruktor. Pak by bylo potřeba použít synchronizaci.
synchronized (A.class) { ... }), a synchronizovaný blok má bariéru na začátku i na konci. Zkusil jsem si to najít a ve třetím vydání JLS je to v kapitole 12.4.2.
Inicializace tridy muze probehnout pouze v jednom vlakne, viz specifikace.To máte pravdu, ale to neříká vůbec nic o tom, co v tu chvíli mohou nebo nemohou dělat jiná vlákna.
S zadnymi pametovymi barierami to nesouvisi.Ale souvisí, jedině díky paměťovým bariérám to probíhá tak, jak psal Jehovista a Ladicek. Každá třída má příznak, zda právě probíhá inicializace, a přístup k tomuto příznaku je synchronizován. Takže na konci inicializace třídy musí nejprve doběhnout všechny části inicializace i z pohledu jiných vláken (a jiných procesorů), teprve pak může být získán zámek a zrušen příznak, že probíhá inicializace. Pokud během inicializace jiné vlákno chce třídu inicializovat, zjistí podle příznaku, že už inicializaci provádí jiné vlákno, a čeká na její dokončení (opět přes
wait(), takže je tam paměťová bariéra).
V tomto konkretnim pripade nemuze getInstance nikdy vratit null, protoze metoda se muze zavolat az po inicializaci, ve ktere se do promenne INSTANCE prirazuje vysledek volani new, ktery nemuze byt nikdy null.To zjevně není pravda – během inicializace se volá metoda-konstruktor, s jejím voláním nemůžete čekat, než proběhne celá inicializace a tedy zároveň proběhne celá tato metoda. Pokud by se vám konstruktor nezdál jako typický příklad metody, představte si volání
SVG.getInstance() v rámci volání toho konstruktoru.
Tiskni
Sdílej: