Radicle byl vydán ve verzi 1.6.0 s kódovým jménem Amaryllis. Jedná se o distribuovanou alternativu k softwarům pro spolupráci jako např. GitLab.
Zemřel Scott Adams, tvůrce komiksových stripů Dilbert parodujících pracovní prostředí velké firmy.
Sdružení CZ.NIC vydalo novou verzi Knot Resolveru (6.1.0). Jedná se o první vydanou stabilní verzi 6, která je nyní oficiálně preferovanou a doporučovanou verzí, namísto předešlé verze 5. Více o Knot Resolveru 6 je možné se dočíst přímo v dokumentaci.
Byl vydán Linux Mint 22.3 s kódovým jménem Zena. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze, že nástroj Systémová hlášení (System Reports) získal mnoho nových funkcí a byl přejmenován na Informace o systému (System Information). Linux Mint 22.3 bude podporován do roku 2029.
Wine bylo po roce vývoje od vydání verze 10.0 vydáno v nové stabilní verzi 11.0. Přehled novinek na GitLabu. Vypíchnuta je podpora NTSYNC a dokončení architektury WoW64.
Byl vydán Mozilla Firefox 147.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Firefox nově podporuje Freedesktop.org XDG Base Directory Specification. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 147 bude brzy k dispozici také na Flathubu a Snapcraftu.
Asociace repair.org udělila anticeny těm nejhorším produktům představeným na veletrhu CES 2026. Oceněnými jsou například šmírující kamery Amazon Ring AI, chytrý běžecký pás od společnosti Merach, která otevřeně přiznává, že nedokáže zabezpečit osobní data uživatelů, případně jednorázové lízátko, které rozvibrovává čelisti uživatele a tak přehrává hudbu. Absolutním vítězem je lednička od Samsungu, která zobrazuje reklamy a kterou lze otevřít pouze hlasovým příkazem přes cloudovou službu.
Íránští protirežimní aktivisté si všímají 30% až 80% ztráty packetů při komunikaci se satelity služby Starlink. Mohlo by se jednat o vedlejší důsledek rušení GPS, kterou pozemní přijímače Starlinku používají k výpočtu polohy satelitů a kterou se režim rovněž snaží blokovat, podle bezpečnostního experta a iranisty Amira Rashidiho je ale pravděpodobnější příčinou terestrické rušení přímo satelitní komunikace Starlinku podobnou
… více »Evropská komise (EK) zvažuje, že zařadí komunikační službu WhatsApp americké společnosti Meta mezi velké internetové platformy, které podléhají přísnější regulaci podle unijního nařízení o digitálních službách (DSA). Firmy s více než 45 miliony uživatelů jsou podle DSA považovány za velmi velké on-line platformy (Very Large Online Platforms; VLOP) a podléhají přísnějším pravidlům EU pro internetový obsah. Pravidla po
… více »Tržní hodnota technologické společnosti Alphabet poprvé v historii přesáhla čtyři biliony dolarů (83 bilionů Kč). Stalo se tak poté, co Apple oznámil, že bude na poli umělé inteligence (AI) spolupracovat s dceřinou firmou Alphabetu, společností Google.
if ($url == 'foo'){
$a = 10;
return;
}
Řešení dotazu:
return slouží pro návrat z funkce, nikoliv pro ukončení cyklu. Pokud je ten kód součástí funkce, return tam použít můžeš.
if(x>0) printf("Cislo je vetsi nez nula.\n");
else printf("Cislo neni vetsi nez nula.\n");
printf("A pokračujem společným kodem.\n")
if(x>0) printf("Cislo je vetsi nez nula.\n");
else printf("Cislo neni vetsi nez nula.\n");
return;
Podle mě je to takto přehlednější, ale samozřejmě každý má jiné zvyky.
Spíš jde o tohle:
void napi_consume_skb(struct sk_buff *skb, int budget)
{
if (unlikely(!skb))
return;
/* dalších 20 řádků vlastního kódu funkce */
}
Samozřejmě můžete celý ten zbytek těla funkce, tj. celou její podstatu, odsadit a dát do else větve (nebo spíš rovnou otočit tu podmínku), ale čitelnosti to rozhodně neprospěje.
return je návrat z procedury/funkce. Dokonce se taková struktura poměrně často i používá. V testu if se posoudí, jestli parametry funkce, nebo jiná data, jsou chybně. Pokud jsou, tak nemá smysl ve funkci dále pokračovat, ošetří se chybový návratový stav a returnem se vrací.
ifů…
returnů sekat goto na něj. :-)
IF proměnná negativ,zero,positivese třemi labely. kdy kód za žádné podmínky nemusel pokračovat za IF.
s oblibou jsem s tím na VŠ provokoval.
Dokonalý chaos ovšem přinášejí interpretované jazyky. Např. "oblíbené"
ON <expr> GOTO <num> [, <num>... ]
v řadě dialektů BASICu a v některých dokonce
GOTO <expr>
Z toho se teoretikům programovacích stylů ježily chlupy i tam, kde netušili, že nějaké mají. :-)
Snad jsem Vám odpověděl.
Mám-li být upřímný, za sebe musím říct, že moc ne. Co se týká review kódu, osobně mnohem radši na začátku funkce uvidím
mp = kzalloc(sizeof(u32) * RTAX_MAX, GFP_KERNEL);
if (unlikely(!mp))
return -ENOMEM;
než aby tam bylo formální "goto out" a já se musel ještě podívat dolů, jestli se v tom případě nedělá něco dalšího. To má naopak dobrý smysl, pokud na konci bude něco jako
err:
kfree(mp);
return -EINVAL;
}
a bude se tam skákat z víc různých míst. Nebo třeba u kaskád jako tady
void copy(source, target) {
if (!file_exists(source)) {
throw "Zdrojový soubor neexistuje.";
}
if (!is_dir(source)) {
throw "Zdroj nemůže být adresář.";
}
if (!is_readable(source)) {
throw "Zdrojový soubor nelze číst.";
}
if (!is_dir(target)) {
throw "Cíl nemůže být adresář.";
}
parent = parent_dir(target);
if (!file_exists(parent)) {
throw "Neexistuje adresář pro cílový soubor.";
}
if (exists(target)) {
throw "Cílový soubor již existuje.";
}
if (!is_writable(parent)) {
throw "Do cílového adresáře nelze zapisovat.";
}
if (get_free_space(parent) < get_file_size(source)) {
throw "V cílovém adresáři není dost volného místa.";
}
buffer, offset;
do {
buffer = read(source, offset, size(buffer));
write(target, offset, buffer);
offset += size(buffer);
} while(size(buffer) > 0);
}
Když to přepíšu na jediný výstupní bod, dostanu:
void copy(source, target) {
error = null;
if (file_exists(source)) {
if (is_dir(source)) {
if (is_readable(source)) {
parent = parent_dir(target);
if (file_exists(parent)) {
if (is_dir(target)) {
if (is_writable(parent)) {
if (!exists(target)) {
if (get_free_space(parent) >= get_file_size(source)) {
buffer, offset;
do {
buffer = read(source, offset, size(buffer));
write(target, offset, buffer);
offset += size(buffer);
} while(size(buffer) > 0);
} else {
error = "V cílovém adresáři není dost volného místa.";
}
} else {
error = "Cílový soubor již existuje.";
}
} else {
error = "Do cílového adresáře nelze zapisovat.";
}
} else {
error = "Cíl nemůže být adresář.";
}
} else {
error = "Neexistuje adresář pro cílový soubor.";
}
} else {
error = "Zdrojový soubor nelze číst.";
}
} else {
error = "Zdroj nemůže být adresář.";
}
} else {
error = "Zdrojový soubor neexistuje.";
}
throw error;
}
Pro mne je tedy ten druhý kód daleko nepřehlednější, a porušuje například jednu velmi dobrou zásadu omezující počet vnoření bloků. Nebo jak byste ten kód přepsal na jediný výstupní bod bez těch vnořených ifů? Počet vnoření by se samozřejmě dal zredukovat sloučením několika testů do jednoho a vytknutím do samostatné funkce, ale to neřeší princip problému.
Možná je rozdíl v programování triviálních funkcí přímo nad procesorem, kde máte jasně definované podmínky běhu, a pokud se náhodou dostanete mimo ně, zastavíte procesor a nějaký watchdog rozsvítí červenou kontrolku, že je všechno špatně (a mimochodem reset procesoru podle mne je výstupní bod, je to obdoba vyhození výjimky ve vyšších programovacích jazycích a způsob, jakým se ukončí provádění dané funkce). A v programování pro počítače, tablety, mobily, televize apod., kde uživatel pracuje přímo s programem, podmínky jsou velmi různorodé a každý očekává, že se z nečekaných situací dokáže program zotavit.
Tiskni
Sdílej: