Byla vydána verze 1.91.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.
Ministerstvo průmyslu a obchodu vyhlásilo druhou veřejnou soutěž v programu TWIST, který podporuje výzkum, vývoj a využití umělé inteligence v podnikání. Firmy mohou získat až 30 milionů korun na jeden projekt zaměřený na nové produkty či inovaci podnikových procesů. Návrhy projektů lze podávat od 31. října do 17. prosince 2025. Celková alokace výzvy činí 800 milionů korun.
Google v srpnu oznámil, že na „certifikovaných“ zařízeních s Androidem omezí instalaci aplikací (včetně „sideloadingu“) tak, že bude vyžadovat, aby aplikace byly podepsány centrálně registrovanými vývojáři s ověřenou identitou. Iniciativa Keep Android Open se to snaží zvrátit. Podepsat lze otevřený dopis adresovaný Googlu nebo petici na Change.org.
Byla vydána nová verze 18 integrovaného vývojového prostředí (IDE) Qt Creator. S podporou Development Containers. Podrobný přehled novinek v changelogu.
Cursor (Wikipedie) od společnosti Anysphere byl vydán ve verzi 2.0. Jedná se o multiplatformní proprietární editor kódů s podporou AI (vibe coding).
Google Chrome 142 byl prohlášen za stabilní. Nejnovější stabilní verze 142.0.7444.59 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 20 bezpečnostních chyb. Za nejvážnější z nich bylo vyplaceno 50 000 dolarů. Vylepšeny byly také nástroje pro vývojáře.
Pro moddery Minecraftu: Java edice Minecraftu bude bez obfuskace.
Národní identitní autorita, tedy NIA ID, MeG a eOP jsou nedostupné. Na nápravě se pracuje [𝕏].
Americký výrobce čipů Nvidia se stal první firmou na světě, jejíž tržní hodnota dosáhla pěti bilionů USD (104,5 bilionu Kč). Nvidia stojí v čele světového trhu s čipy pro umělou inteligenci (AI) a výrazně těží z prudkého růstu zájmu o tuto technologii. Nvidia již byla první firmou, která překonala hranici čtyř bilionů USD, a to letos v červenci.
Po Canonicalu a SUSE oznámil také Red Hat, že bude podporovat a distribuovat toolkit NVIDIA CUDA (Wikipedie).
Makefile scanner-test.c scanner.c scanner.h str.c str.ha pri prekladu pres make mi to stale haze toto:
$ make gcc -Wall -std=c99 -pedantic -lm -c scanner-test.c gcc -Wall -std=c99 -pedantic -lm -c scanner.c gcc -Wall -std=c99 -pedantic -lm -c str.c gcc -Wall -std=c99 -pedantic -lm scanner-test.o scanner.o str.o -o scanner-test scanner.o:(.data+0x0): multiple definition of `keywords' scanner-test.o:(.data+0x0): first defined here collect2: ld returned 1 exit status make: *** [scanner-test] Error 1keywords je pole, ktere je definovane POUZE jednou v souboru scanner.h. Mam podezreni, ze za toto muze muj Makefile. Ten vypada takto:
CC=gcc CFLAGS=-Wall -std=c99 -pedantic -lm all: scanner-test scanner-test: scanner-test.o scanner.o str.o $(CC) $(CFLAGS) scanner-test.o scanner.o str.o -o scanner-test scanner.o: scanner.c str.h $(CC) $(CFLAGS) -c scanner.c str.o: str.c str.h $(CC) $(CFLAGS) -c str.c scanner-test.o: scanner-test.c str.h scanner.h $(CC) $(CFLAGS) -c scanner-test.c clean: rm -f *.o *.out $(PRJ)Nezda se mi vsak, ze by se tam neco natahovalo 2x. Uz jsem z toho zoufaly, hledani teto priciny mi uz zabralo vice casu nez samotne napsani programu, muzete mi prosim poradit? Dekuji.
CC=gcc CFLAGS=-Wall -std=c99 -pedantic -lm all: str.o scanner.o scanner-test.o $(CC) $(CFLAGS) -o scanner-test str.o scanner.o scanner-test.o clean: rm -f *.o *.out $(PRJ)Jeste popisu co jednotlive souboru includuji:
scanner.c     <-- scanner.h
                  str.h
str.c         <-- str.h
scanner-test  <-- str.h
                  scanner.h
Vsechny hlavickove soubory jsou opatreny konstrukci
#ifndef XXX #define XXX ... #endif
#ifndef TESTYTESTY_H
#define TESTYTESTY_H
cosi
#endif
a.h ---- extern int a;
a.c ---- int a = 0;pak to zacne fungovat.
$ make gcc -Wall -std=c99 -pedantic -lm -c -o str.o str.c gcc -Wall -std=c99 -pedantic -lm -c -o scanner.o scanner.c In file included from scanner.c:5: scanner.h:12: warning: ‘keywords’ initialized and declared ‘extern’ gcc -Wall -std=c99 -pedantic -lm -c -o scanner-test.o scanner-test.c In file included from scanner-test.c:4: scanner.h:12: warning: ‘keywords’ initialized and declared ‘extern’ gcc -Wall -std=c99 -pedantic -lm -o scanner-test str.o scanner.o scanner-test.o scanner-test.o:(.data+0x0): multiple definition of `keywords' scanner.o:(.data+0x0): first defined here collect2: ld returned 1 exit status make: *** [all] Error 1Nepomohlo:/
static const char* keywords[] = {
    ...
};
make:
$ make gcc -Wall -std=c99 -pedantic -lm -c -o str.o str.c gcc -Wall -std=c99 -pedantic -lm -c -o scanner.o scanner.c gcc -Wall -std=c99 -pedantic -lm -c -o scanner-test.o scanner-test.c scanner.h:12: warning: ‘keywords’ defined but not used gcc -Wall -std=c99 -pedantic -lm -o scanner-test str.o scanner.o scanner-test.oNejak to ale nechapu, proc jsem musel promennou deklarovat jako static? Jako deklarace te promenne je v souboru scanner.h. Jeji pouziti je vsak ve scanner.c. Jaktoze si tedy scanner.c nestezuje, ze nevidi definici teto promenne?
const char* keywords[] = {
    ...
};
presouvat ze scanner.h do scanner.c, vzdyt od toho mimo jine scanner.h, je? Na deklaraci promennych a typu, ktere pak pouziva *.c soubor.
            Když napíšete
int a; int b = 5;
tak obě proměnné zároveň definujete, tj. v příslušném modulu bude tato proměnná vytvořena (jestli tam máte nebo nemáte inicializaci, nehraje roli). Napíšete-li takovou věc do hlavičkového souboru, proměnná se vytvoří v každém modulu, do kterého ho includujete, takže linker dostane kolizi. Když ale napíšete
extern int a; extern int b;
řeknete tím překladači, že proměnné a, b jsou typu int, ale že je v tomto modulu nemá vytvářet, protože jsou definovány jinde (tj. externě). První příklad odpovídá definici funkce (tj. včetně těla), zatímco druhý její deklaraci (jen hlavička).
Takže správný postup, jak už tu padlo, je
extern const char* keywords[];
ve scanner.h a
  extern const char* keywords[] = {
    ...
  };
ve scanner.c, čímž zajistíte, že ve všech modulech (kde se includuje scanner.h) budete mít proměnnou deklarovanou, ale vytvoří se jen ve scanner.o, takže linker na žádnou kolizi nenarazí. Použití static je v tomto případě chybné, protože to by znamenalo, že to sice kolidovat nebude, ale jen proto, že každý modul bude mít svou vlastní proměnnou stejného jména.
scanner.c ma byt
const char* keywords[] = { // bez extern
    ...
};
jinak to bude kolegovi pri linkovani pro zmenu rvat, ze keywords neexistuje.
            vzdyt od toho mimo jine scanner.h, je? Na deklaraci promennych a typu, ktere pak pouziva *.c soubor.
Ne tak docela. Hlavičkový soubor slouží především k deklaraci funkcí/proměnných které využívají jiné moduly. Pokud, jak zde píšete, proměnnou/datový typ používáte pouze a jenom v *.c souboru příslušném k danému *.h souboru, je více než moudré proměnnou v hlavičkovém souboru neuvádět a navíc jí deklarovat jako static. Předejdete tak problémům se stejně pojmenovanými "lokálními" funkcemi/proměnnými a "zpřehledníte" informaci o tom, co vlastně daný modul exportuje.
        Tiskni
            
                Sdílej:
                 
                 
                 
                 
                 
                