Byla vydána (𝕏) nová verze 24.7 open source firewallové a routovací platformy OPNsense (Wikipedie). Jedná se o fork pfSense postavený na FreeBSD. Kódový název OPNsense 24.7 je Thriving Tiger. Přehled novinek v příspěvku na fóru.
Binarly REsearch upozorňuje na bezpečnostní problém PKFail (YouTube) v ekosystému UEFI. Stovky modelů zařízení používají pro Secure Boot testovací Platform Key vygenerovaný American Megatrends International (AMI) a jeho privátní část byla při úniku dat prozrazena. Do milionů zařízení (seznam v pdf) po celém světě tak útočníci mohou do Secure Bootu vložit podepsaný malware. Otestovat firmware si lze na stránce pk.fail. Ukázka PoC na Linuxu na Windows na YouTube.
Mobilní operační systém /e/OS (Wikipedie) založený na Androidu / LineageOS, ale bez aplikací a služeb od Googlu, byl vydán ve verzi 2.2 (Mastodon, 𝕏). Přehled novinek na GitLabu. Vypíchnuta je rodičovská kontrola.
Společnost OpenAI představila vyhledávač SearchGPT propojující OpenAI modely umělé inteligence a informace z webů v reálném čase. Zatím jako prototyp pro vybrané uživatele. Zapsat se lze do pořadníku čekatelů.
Distribuce Linux Mint 22 „Wilma“ byla vydána. Je založená na Ubuntu 24.04 LTS, ale s desktopovým prostředím Cinnamon (aktuálně verze 6.2), příp. MATE nebo Xfce, balíkem aplikací XApp, integrací balíčků Flatpak a dalšími změnami. Více v přehledu novinek a poznámkách k vydání.
Příspěvek na blogu Truffle Security: Kdokoli může přistupovat ke smazaným a privátním repozitářům na GitHubu.
Byla vydána nová verze 14 integrovaného vývojového prostředí (IDE) Qt Creator. Podrobný přehled novinek v cgitu. Vypíchnout lze podporu rozšíření v Lua.
Byla vydána verze 1.80.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.
Apple oznámil, že v beta verzi spustil své Apple Maps na webu. Podporován je také webový prohlížeč Chrome. Ne však na Linuxu.
Portál Stack Overflow po roce opět vyzpovídal své uživatele, jedná se především o vývojáře softwaru, a zveřejnil detailní výsledky průzkumu. Průzkumu se letos zúčastnilo více než 65 tisíc vývojářů. Z Česka jich bylo 710. Ze Slovenska 246.
int main(void){
int i;
i = 0;
int vstup;
scanf("%d", &vstup);
for(int r[i]; r[i] < vstup; i++){
r[0] = 5;
printf("%d", r);
}
return 0;
}
Nevite proc? Nema to zadny vystup, ale mel by tam byt printf("%d", r);
------------------------------------------------------------------------
Nefunguje ani tohle. Ale tohle alespon neco vypise. (vypise to nulu)
int main(void){
int i,r;
i = 0;
int vstup;
scanf("%d", &vstup);
for(int r[i]; i < vstup; i++)
r[0] = 5;
printf("%d", r);
return 0;
}
Řešení dotazu:
int r[i];vytvoří na zásobníku neinicializované pole nulové velikosti (to je samo o sobě dost pochybné). Takže hned první podmínka v tom for-cyklu udělá sáhne do neinicializované části zásobníku. Výsledek je náhodný, ale s větší pravděpodobností se cyklus hned ukončí... Celkově ten cyklus nemůže udělat nic smysluplného. To r uvnitř cyklu nemá nic společného s r vně cyklu, je to nová proměnná!
Nevím jak to souvisí s bitovým polem, ale první i druhé je dost blbě, deklaruješ pole nulové délky int r[i]
(bo i = 0
)
a pak přistupuješ na jeho první prvek
r[i]
A dokonce tam chceš zapisovat za pseudo-náhodných podmínek
r[0] = 5
Deklarací r
v prvním řádku je zbytečná, r
není nikde použito, a zapisujete do nealokovaného prostoru při zadání vstupu >= 0.
Něco vypíše, protože je tam printf, který se provede vždy na rozdíl od prvního příkladu.
Jen matně hádám čeho chceš docílit, takže nemůžu napsat jak to má být…
Tiskni
Sdílej: