Dnes ve 12:00 byla spuštěna první aukce domén .CZ. Zatím největší zájem je o dro.cz, kachnicka.cz, octavie.cz, uvycepu.cz a vnady.cz [𝕏].
JackTrip byl vydán ve verzi 2.3.0. Jedná se o multiplatformní open source software umožňující hudebníkům z různých částí světa společné hraní. JackTrip lze instalovat také z Flathubu.
Patnáctý ročník ne-konference jOpenSpace se koná 4. – 6. října 2024 v Hotelu Antoň v Telči. Pro účast je potřeba vyplnit registrační formulář. Ne-konference neznamená, že se organizátorům nechce připravovat program, ale naopak dává prostor všem pozvaným, aby si program sami složili z toho nejzajímavějšího, čím se v poslední době zabývají nebo co je oslovilo. Obsah, který vytváří všichni účastníci, se skládá z desetiminutových
… více »Program pro generování 3D lidských postav MakeHuman (Wikipedie, GitHub) byl vydán ve verzi 1.3.0. Hlavní novinkou je výběr tvaru těla (body shapes).
Intel vydal 41 upozornění na bezpečnostní chyby ve svých produktech. Současně vydal verzi 20240514 mikrokódů pro své procesory řešící INTEL-SA-01051, INTEL-SA-01052 a INTEL-SA-01036.
Společnost Raspberry Pi patřící nadaci Raspberry Pi chystá IPO a vstup na Londýnskou burzu.
Google na své vývojářské konferenci Google I/O 2024 představil řadu novinek. Keynote byl věnován umělé inteligenci (DeepMind, Gemini, Responsible AI).
V Gitu bylo nalezeno 5 zranitelností. Opraveny jsou ve verzích 2.45.1, 2.44.1, 2.43.4, 2.42.2, 2.41.1, 2.40.2 a 2.39.4. Útočník může připravit repozitář tak, že při jeho klonování (git clone) může dojít ke spuštění libovolného kódu.
Virtualizační softwary VMware Workstation Pro a VMware Fusion Pro jsou nově pro osobní použití zdarma. Softwary VMware Workstation Player a VMware Fusion Player končí.
Linuxová distribuce Endless OS (Wikipedie) byla vydána ve verzi 6.0.0. Přehled novinek i s náhledy v příspěvku na blogu, poznámkách k vydání a také na YouTube.
Vyšla nová verze debuggeru GDB, 6.8. Lze jej zkompilovat (do jedné binárky) tak, aby podporoval několik architektur (vzdálené cíle). Přidává podporu pro NetBSD/hppa a Xtensa GNU/Linux. Byla vylepšena podpora programovacího jazyka Ada a debugování optimalizovaného kódu. Připojování k programu pomocí přepínače '-c' již není podporováno, používá se '-p' (--pid).
Tiskni Sdílej:
#include <pthread.h>
#include <stdio.h>
#include <unistd.h>
void* print_pokus(void *unused)
{
while(1)
{
printf(" %s\n", (char *)unused);
}
return(NULL);
}
int main()
{
pthread_t thread_id1;
pthread_t thread_id2;
pthread_t thread_id3;
pthread_create(&thread_id1, NULL, &print_pokus, "1");
pthread_create(&thread_id2, NULL, &print_pokus, "2");
pthread_create(&thread_id3, NULL, &print_pokus, "3");
while(1)
{
sleep(1);
}
return(0);
}
#include <pthread.h>
#include <stdio.h>
#include <unistd.h>
static pthread_mutex_t mutex;
void* print_pokus(void *unused)
{
while(1)
{
pthread_mutex_lock(&mutex);
printf(" %s\n", (char *)unused);
pthread_mutex_unlock(&mutex);
}
return(NULL);
}
int main()
{
pthread_t thread_id1;
pthread_t thread_id2;
pthread_t thread_id3;
pthread_mutex_init(&mutex, NULL);
pthread_create(&thread_id1, NULL, print_pokus, "1");
pthread_create(&thread_id2, NULL, print_pokus, "2");
pthread_create(&thread_id3, NULL, print_pokus, "3");
while(1)
{
sleep(1);
}
return(0);
}
char* string; ziskej_mutex() string = malloc(100); if (string != NULL) memcpy(string,zdroj,100); vrat_mutex(); ... ziskej_mutex(); free(string); vrat_mutex();Céčko by bylo zhola nepoužitelné, pokud by C knihovna nebyla vnitřně multithreadová.
pokud se zhroutí debugger u _jakéhokoli_ zdrojáku, pak je to špatný debuggerNebo je v něm prostě chyba, že?
A zde se rozmáhá nešvar na abclinuxu jásat nedávno nad linkerem, který linkuje několikrát rychleji - co na tom, že neumí spolehlivě linkovat - kdo by se zdržoval takovou maličkostí, že?Jásalo se nad tím, že se novej a rychlej linker vyvíjí, nevím co je na tom za nešvar. Třeba já z něj mám radost, ale nepoběžím si ho hned nainstalovat.
Přemýšlím, jestli lze udělat debugger pro nativní kód, který přežije libovolně ošklivé chování laděného programu... Ale jinak, Miroslave, s tou spolehlivostí programátorských nástrojů, to máte pravdu. Kdysi jsem narazil na chybu v Borland C++ Builderu, kdy pořádně nefungovala šablona std::list, no to byl vomrd. Proto mám rád GCC. Jistě má své chyby, ale žiju s vědomím, že když to přeloží kompletní linuxovou distribuci, tak to snad nezhučí na mém tic-tac-toe, alébrž vygeneruje validní kódpokud se zhroutí debugger u _jakéhokoli_ zdrojáku, pak je to špatný debuggerNebo je v něm prostě chyba, že?
0x080484f4 <print_pokus+0>: push %ebp
0x080484f5 <print_pokus+1>: mov %esp,%ebp
0x080484f7 <print_pokus+3>: sub $0x8,%esp
0x080484fa <print_pokus+6>: int3
0x080484fb <print_pokus+7>: add $0x24,%al
0x080484fd <print_pokus+9>: int3
0x080484fe <print_pokus+10>: xchg %eax,%edi
0x080484ff <print_pokus+11>: add $0x8,%al
0x08048501 <print_pokus+13>: call 0x8048440 <pthread_mutex_lock@plt>
0x08048506 <print_pokus+18>: int3
0x08048507 <print_pokus+19>: inc %ebp
0x08048508 <print_pokus+20>: or %cl,0xc7042444(%ecx)
0x0804850e <print_pokus+26>: add $0x24,%al
0x08048510 <print_pokus+28>: cwtl
0x08048511 <print_pokus+29>: xchg %al,(%eax,%ecx,1)
0x08048514 <print_pokus+32>: call 0x8048420 <printf@plt>
0x08048519 <print_pokus+37>: movl $0x80497cc,(%esp)
Pri debugovani debuger dava do strojoveho kodu int3, ked vsak prepne na nejake ine vlakno, zabude tuto intrukciu inemu vlaknu zobrat, cim sa poskodi kod. Ked kazde vlakno poziva svoju vlastnu funkciu, nie su v tej funkcii int3 z debugovani inych vlakien. Samozrejme debuger by mal podporovat debugovat funkcie, ktore su pozivane sucastne viac vlaknami
gdb --help|grep bugs Report bugs to "bug-gdb@gnu.org".