Český úřad zeměměřický a katastrální zavedl u anonymního nahlížení do katastru nemovitostí novou CAPTCHA ve formě mapové puzzle: nepřihlášení uživatelé musí nově správně otočit devět dlaždic v 3x3 poli tak, aby dohromady daly souvislý obrázek výseče reálné mapy, přičemž na to mají pouze jeden časově omezený pokus. Test je podle uživatelů i odborníků příliš obtížný a na sociálních sítích pochopitelně schytává zaslouženou kritiku a
… více »Byla vydána verze 1.95.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.
Mozilla prostřednictvím své dceřiné společnosti MZLA Technologies Corporation představila open-source AI klienta Thunderbolt. Primárně je určený pro firemní nasazení.
Firma Cal.com oznámila, že přesouvá svůj produkční kód z otevřeného do uzavřeného repozitáře z důvodu bezpečnostního rizika umělé inteligence, která prý dokáže vyhledávat a zneužívat zranitelnosti rychleji, než by je jejich vývojářský tým stíhal opravovat. Zároveň zveřejnila samostatnou, open-source verzi Cal.diy pod licencí MIT, ovšem bez řady původních funkcí. O tom, zda je toto opatření rozumné, existují pochyby. … více »
Vývojáři KDE na Mastodonu oznámili vydání balíku aplikací KDE Gear 26.04. Přehled novinek i s náhledy a videi v oficiálním oznámení.
Kryptografická knihovna OpenSSL byla vydána v nové verzi 4.0. Přehled změn v souboru CHANGES.md na GitHubu. Odstraněna byla podpora SSLv2 Client Hello a SSLv3. Ve výchozím nastavení byla zakázána podpora odmítnutých eliptických křivek v TLS dle RFC 8422. Přibyla například podpora Encrypted Client Hello (ECH, RFC 9849).
curl up 2026, tj. setkání vývojářů a uživatelů curlu, proběhne opět v Praze. O víkendu 23. a 24. května v Pracovně.
Aplikace pro ověřování věku uživatelů on-line platforem je technicky hotová a brzy bude k dispozici pro občany EU, oznámila dnes předsedkyně Evropské komise Ursula von der Leyenová. Půjde podle ní o bezplatné a snadno použitelné řešení, které pomůže chránit děti před škodlivým a nelegálním obsahem. Aplikace bude podle ní fungovat na jakémkoli zařízení a bude zcela anonymní.
V prosinci 2012 byla z linuxového jádra odstraněna podpora procesorů 386. Včera započalo odstraňování podpory procesorů 486.
IuRe (Iuridicum Remedium) vyhlásila Ceny Velkého bratra za rok 2025. Slídily roku jsou automobilka Volkswagen, Meta a česká Ministerstva vnitra a průmyslu a obchodu. Autorem Výroku Velkého bratra je dánský ministr spravedlnosti zpochybňující právo na šifrovanou komunikaci. Naopak Pozitivní cenu získali studenti Masarykovy univerzity za odpor proti nucení do používaní aplikace ISIC.
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: