Sovereign Tech Fund oznámil finanční podporu následujících open source projektů: Scala, SDCC, Let's Encrypt, Servo, chatmail, Drupal, Fedify, openprinting, PHP, Apache Arrow, OpenSSL, R Project, Open Web Docs, conda, systemd a phpseclib.
Bylo vydáno OpenBSD 7.8. S předběžnou podporou Raspberry Pi 5. Opět bez písničky.
Valkey (Wikipedie) byl vydán v nové major verzi 9.0. Valkey je fork Redisu.
Byly publikovány informace o kritické zranitelnosti v knihovně pro Rust async-tar a jejích forcích tokio-tar, krata-tokio-tar a astral-tokio-tar. Jedná se o zranitelnost CVE-2025-62518 s CVSS 8.1. Nálezci je pojmenovali TARmageddon.
AlmaLinux přinese s verzí 10.1 podporu btrfs. XFS bude stále jako výchozí filesystém, ale instalátor nabídne i btrfs. Více informací naleznete v oficiálním oznámení.
Společnost OpenAI představila svůj vlastní webový prohlížeč ChatGPT Atlas. Zatím je k dispozici pouze na macOS.
Desktopové prostředí KDE Plasma bylo vydáno ve verzi 6.5 (Mastodon). Přehled novinek i s videi a se snímky obrazovek v oficiálním oznámení. Podrobný přehled v seznamu změn.
Rodina jednodeskových počítačů Orange Pi se rozrostla (𝕏) o Orange Pi 6 Plus.
Na Humble Bundle běží akce Humble Tech Book Bundle: All Things Raspberry Pi by Raspberry Pi Press. Se slevou lze koupit elektronické knihy od nakladatelství Raspberry Pi Press a podpořit Raspberry Pi Press, Raspberry Pi Foundation North America nebo Humble.
Přidaný režim autonomního řízení vozidel Tesla Mad Max je dostupný pro vybrané zákazníky v programu EAP (Early Access Program). Nový režim je na silnici agresivnější, častěji mění pruhy a ne vždy dodržuje rychlostní limity. Agentura JPP spekuluje, že v Česku by se mohl nový režim namísto Mad Max jmenovat Mad Turek...
Řešení dotazu:
cislo & 1 == 1
. Při dělení celého čísla celým číslem, dostanu opět celé číslo se zahozeným zbytkem (např. 26/10=2
). Budu-li chtít zjistit sudost čísla pomocí dělení, musím vydělit číslo dvojkou, pak vynásobit dvojkou a porovnat s původním číslem, jestli jsem dostal to samé. Což znamená výrazně vyšší časovou složitost.
Moc pěkné využití bitových operátorů je pro masky. Představte si, že máte nějaký systém, do kterého přistupuje více lidí. Těmto lidem chceme udělovat nějaká oprávnění. Daný člověk oprávnění buďto má, nebo nemá. Žádná jiná možnost není přípustná. Tato oprávnění seřadím v libovolném pořadí. Teď už mi stačí udělat jen to, že každému uživateli přiřadím jedno číslo ve dvojkové soustavě, které bude reprezentovat jeho množinu oprávnění. Na dané pozici bude 1, pokud oprávnění má, a 0, pokud ne. Zjišťování a nastavování oprávnění lze jednoduše implementovat pomocí binárních operátorů při velice nízké spotřebě procesorového času i paměti.
Máte-li dvě proměnné typu char
, můžete na ně bez problémů použít OR. Následující kód tedy bude fungovat bez problémů:
char a = 'A'; char b = 'B'; char c = a | b;
return a*5;
versus return (a<<2)+a;
a při kompilaci GCC už při optimalizaci -O1
z obou zápisů vygeneroval naprosto shodný assembler. Takže myslím, že u toho dělení to bude stejně tak a programátor se nemusí o optimalizaci na této úrovni starat, neboť to za něj udělá překladač.
#define EXECUTE (1 << 0) // 0. bit #define WRITE (1 << 1) // 1. bit #define READ (1 << 2) // 2. bitTaková práva lze potom snadno testovat právě pomocí binárních operací:
if (perm & EXECUTE) { // Lze spouštět } if (perm & (READ | WRITE)) { // Lze číst i zapisovat }Stejně tak je lze i měnit:
perm &= ~EXECUTE; // Nyní je (perm & EXECUTE) vždy nepravdivé, tj. 0. bit je vždy 0 perm |= WRITE; // Nyní je (perm & WRITE) vždy pravdivé, tj. 1. bit je vždy 1
if (perm & (READ | WRITE)) { // Špatně: Lze číst i zapisovat // Správně: Lze číst nebo zapisovat (nebo oboje) } if ((perm & READ) && (perm & WRITE)) { // Lze číst i zapisovat // "moderní" styl // Nemusí být bezpečné, pro masky pouze s jedním bitem! } if (perm & (READ | WRITE) == (READ | WRITE)) { // Lze číst i zapisovat // "klasický" styl // Bezpečné, i pro masky, které mohou mít více bitů (zde díky použití |) // Pokud má maska jenom jeden bit, kompilátor to porování stejně odstraní }
Tiskni
Sdílej: