Na YouTube byly zveřejněny videozáznamy přednášek z hackerské konference DEF CON 33, jež proběhla 7. až 10. srpna v Las Vegas.
Bun (Wikipedie), tj. běhové prostředí (runtime) a toolkit pro JavaScript a TypeScript, alternativa k Node.js a Deno, byl vydán ve verzi 1.3. Představení novinek také na YouTube. Bun je naprogramován v programovacím jazyce Zig.
V Lucemburku byly oznámeny výsledky posledního kola výzev na evropské továrny pro umělou inteligenci neboli AI Factories. Mezi úspěšné žadatele patří i Česká republika, potažmo konsorcium šesti partnerů vedené VŠB – Technickou univerzitou Ostrava. V rámci Czech AI Factory (CZAI), jak se česká AI továrna jmenuje, bude pořízen velmi výkonný superpočítač pro AI výpočty a vznikne balíček služeb poskytovaný odborníky konsorcia. Obojí bude sloužit malým a středním podnikům, průmyslu i institucím veřejného a výzkumného sektoru.
Byla vydána (𝕏) zářijová aktualizace aneb nová verze 1.105 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.105 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.
Ve Firefoxu bude lepší správa profilů (oddělené nastavení domovské stránky, nastavení lišt, instalace rozšíření, uložení hesla, přidání záložky atd.). Nový grafický správce profilů bude postupně zaváděn od 14.října.
Canonical vydal (email) Ubuntu 25.10 Questing Quokka. Přehled novinek v poznámkách k vydání. Jedná se o průběžné vydání s podporou 9 měsíců, tj. do července 2026.
ClamAV (Wikipedie), tj. multiplatformní antivirový engine s otevřeným zdrojovým kódem pro detekci trojských koní, virů, malwaru a dalších škodlivých hrozeb, byl vydán ve verzi 1.5.0.
Byla vydána nová verze 1.12.0 dynamického programovacího jazyka Julia (Wikipedie) určeného zejména pro vědecké výpočty. Přehled novinek v příspěvku na blogu a v poznámkách k vydání. Aktualizována byla také dokumentace.
V Redisu byla nalezena a v upstreamu již opravena kritická zranitelnost CVE-2025-49844 s CVSS 10.0 (RCE, vzdálené spouštění kódu).
Ministr a vicepremiér pro digitalizaci Marian Jurečka dnes oznámil, že přijme rezignaci ředitele Digitální a informační agentury Martina Mesršmída, a to k 23. říjnu 2025. Mesršmíd nabídl svou funkci během minulého víkendu, kdy se DIA potýkala s problémy eDokladů, které některým občanům znepříjemnily využití možnosti prokázat se digitální občankou u volebních komisí při volbách do Poslanecké sněmovny.
n
procesov a aby kazdy potomok vypisal cislo od 0 po 4. Preco to ale nebezi naraz(paralelne?)
pid_t pid[n+1];
for(p = 0; p < n; p++)
{
pid[p] = fork();
switch(pid[p])
{
case -1:
/* fork error */
PANIC("fork");
break;
case 0:
child = true;
for(int i = 0; i < 5; i++) { printf("%d\n", i); fflush(stdout); }
break;
default:
waitpid(pid[p], NULL, 0);
child = false;
break;
}
if(child) break;
}
printf("--- (%d) => (%d)\n", getppid(), getpid());
Toto je vystup:
0
1
2
3
4
--- (12622) => (12623)
0
1
2
3
4
--- (12622) => (12624)
0
1
2
3
4
--- (12622) => (12625)
0
1
2
3
4
--- (12622) => (12626)
0
1
2
3
4
--- (12622) => (12627)
--- (3683) => (12622)
3683 je bash.
Dakujem za radu
Řešení dotazu:
default:
waitpid(pid[p], NULL, 0);
Ak tomu dobre rozumiem, tak sa hlavny proces najprv zdvoji (fork
),
a pocka waitpid
kym synovsky proces skonci.
A az potom pokracuje vo vykonavani cyklu
n
vlakien:
for(p = 0; p < n; p++)
{
pid[p] = fork();
switch(pid[p])
{
case -1:
/* fork error */
PANIC("fork");
break;
case 0:
child = true;
break;
default:
child = false;
break;
}
if(child) break;
}
if(child)
{
sleep(5);
//do_child_job(p);
}
if(parent)
{
for(p = 0; p < n; p++)
{
printf("parent\n");
waitpid(pid[p], NULL, 0);
}
Problem je vsak, ze ked napriklad 1. child proces nieco robi dlhsie, tak waitpid zablokuje hlavny proces cakanim na skoncenie a az potom sa zavola waitpid na dalsie procesy. Comu ale uz vobec nerozumiem, preco sa tento kod sprava tak, ze da takyto vystup:
parent // tu caka tych 5 sekund
parent // dalsie 4 riadky uz vypise okamzite
parent
parent
parent
Slo by asi pouzit WNOHANG
vo waitpid namiesto 0
, ale potom hlavny proces skonci a nepocka na skoncenie deti.
Ako teda zabezpecit, ze hlavny proces nebude blokovany child procesmy, ale zaroven pocka, kym vsetky skoncia?
static void sigchld_hdl(int sig)
{
running_children--;
printf("sigchld_hdl\n"); fflush(stdout);
/* Wait for all dead processes.
* We use a non-blocking call to be sure this signal handler will not
* block if a child was cleaned up in another part of the program. */
while (waitpid(-1, NULL, WNOHANG) > 0)
{
}
if(running_children == 0) // toto je vlastne na upratanie po detoch, ked uz vsetky su skoncene
{
printf("--QUITING\n"); fflush(stdout);
fclose(fp);
if (msgctl(msqid, IPC_RMID, NULL) == -1)
PANIC("msgctl");
exit(EXIT_SUCCESS);
}
}
potom v main()
struct sigaction act;
memset (&act, 0, sizeof(act));
act.sa_handler = sigchld_hdl;
if (sigaction(SIGCHLD, &act, 0)) {
perror ("sigaction");
return 1;
}
for(p = 0; p < n; p++)
{
pid[p] = fork();
switch(pid[p])
{
case -1:
/* fork error */
PANIC("fork");
break;
case 0:
child = true;
break;
default:
child = false;
running_children++;
printf("adding child: %ld\n", running_children); fflush(stdout);
break;
}
if(child) break;
}
if(child)
{
printf("(%d) cakam...\n", getpid()); fflush(stdout);
msg_rcv(READY_TO_START);
printf("(%d) child\n", getpid()); fflush(stdout);
exit(EXIT_SUCCESS);
// sleep(1);
}
if(parent)
{
for(p = 0; p < n; p++)
{
printf("parent\n"); fflush(stdout);
waitpid(pid[p], NULL, WNOHANG);//WNOHANG
msg_snd(READY_TO_START, READY_TO_START_TRUE);
}
while (running_children>0) {
sleep(1);
printf("sleeping, running children: %ld\n", running_children); fflush(stdout);
}
}
Toto teda vacsinou funguje, avsak niekedy sa to zasekne na tom poslednom while(running_children>0) a vystup je takyto:
$ ./philosophers 5
(26467) >> sending message(1): 1
(26467) >> sending message(2): 0
adding child: 1
(26468) cakam...
adding child: 2
(26469) cakam...
adding child: 3
(26470) cakam...
adding child: 4
(26471) cakam...
adding child: 5
parent
(26467) >> sending message(3): 0
parent
(26468) >> receiving message(3): 0
(26468) child
(26469) >> receiving message(3): 0
(26469) child
sigchld_hdl
(26467) >> sending message(3): 0
parent
(26467) >> sending message(3): 0
parent
(26470) >> receiving message(3): 0
(26470) child
(26471) >> receiving message(3): 0
(26471) child
(26472) cakam...
sigchld_hdl
(26467) >> sending message(3): 0
parent
(26467) >> sending message(3): 0
(26472) >> receiving message(3): 0
(26472) child
sigchld_hdl
sleeping, running children: 2
sleeping, running children: 2
sleeping, running children: 2
sleeping, running children: 2
sleeping, running children: 2
sleeping, running children: 2
sleeping, running children: 2
sleeping, running children: 2
sleeping, running children: 2
^C
Chape to niekto?
Dakujem
Problém už byl vyřešen, ale neodpustím si terminologickou poznámku:
Nasledujuci kod spusti pekne n vlakien:
Syscall fork()
nevytváří vlákna ale procesy. Vlákna by se vytvářela pomocí pthread_create()
.
Tiskni
Sdílej: