Guido van Rossum, tvůrce programovacího jazyka Python, oslavil 70. narozeniny. Narodil se 31. ledna 1956 v nizozemském Haarlemu.
OpenClaw je open-source AI asistent pro vykonávaní různých úkolů, ovládaný uživatelem prostřednictvím běžných chatovacích aplikací jako jsou například WhatsApp, Telegram nebo Discord. Asistent podporuje jak různé cloudové modely, tak i lokální, nicméně doporučován je pouze proprietární model Claude Opus 4.5 od firmy Anthropic v placené variantě. GitHubová stránka projektu OpenClaw.
Projekt VideoLAN a multimediální přehrávač VLC (Wikipedie) dnes slaví 25 let. Vlastní, tenkrát ještě studentský projekt, začal již v roce 1996 na vysoké škole École Centrale Paris. V první únorový den roku 2001 ale škola oficiálně povolila přelicencování zdrojových kódů na GPL a tím pádem umožnila používání VLC mimo akademickou půdu.
Moltbook je sociální síť podobná Redditu, ovšem pouze pro agenty umělé inteligence - lidé se mohou účastnit pouze jako pozorovatelé. Agenti tam například rozebírají podivné chování lidí, hledají chyby své vlastní sociální sítě, případně spolu filozofují o existenciálních otázkách 🤖.
scx_horoscope je „vědecky pochybný, kosmicky vtipný“ plně funkční plánovač CPU založený na sched_ext. Počítá s polohami Slunce a planet, fázemi měsíce a znameními zvěrokruhu. Upozornil na něj PC Gamer.
O víkendu probíhá v Bruselu konference FOSDEM 2026 (Free and Open source Software Developers’ European Meeting). Program konference je velice nabitý: 37 místností, 71 tracků, 1184 přednášejících, 1069 přednášek, prezentací a workshopů. Sledovat je lze i online. K dispozici budou jejich videozáznamy. Aktuální dění lze sledovat na sociálních sítích.
Společnost Nex Computer stojící za "notebooky bez procesorů a pamětí" NexDock představila telefon NexPhone, který může funguje jako desktop PC, stačí k němu připojit monitor, klávesnici a myš nebo NexDock. Telefon by měl být k dispozici ve třetím čtvrtletí letošního roku. Jeho cena by měla být 549 dolarů. Předobjednat jej lze s vratní zálohou 199 dolarů. V dual-bootu by měl být předinstalovaný Android s Linuxem (Debian) jako aplikací a Windows 11.
Byla vydána nová major verze 9.0 softwaru pro správu elektronických knih Calibre (Wikipedie). Přehled novinek v poznámkách k vydání. Vypíchnuta je podpora AI.
Wasmer byl vydán ve verzi 7.0. Jedná se o běhové prostředí pro programy ve WebAssembly. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT.
V reakci na nepopulární plán Microsoftu ještě více ve Windows prohloubit integraci umělé inteligence Copilot, Opera na sociální síti 𝕏 oznámila, že připravuje nativní linuxovou verzi prohlížeče Opera GX. Jedná se o internetový prohlížeč zaměřený pro hráče, přičemž obsahuje všechny základní funkce běžného prohlížeče Opera. Kromě integrace sociálních sítí prohlížeč například disponuje 'omezovačem', který umožňuje uživatelům omezit využití sítě, procesoru a paměti prohlížečem, aby se tak šetřily systémové zdroje pro jinou aktivitu.
FILE *p_f=fopen("soubor.txt","r+");, soubor přitom soubor existuje. Dále mám if(p_f==NULL){
printf("Chyba pri otevirani souboru\n");
fclose(p_f);
}. Všechny potřebné knihovny jsou inkluovány, tak nevím kde je chyba. Googlem brázdím něco přes hodinu a půl a na nic jsem nepřišel. Jen jsem zjistil, že je tam potřeba použít fce malloc, bohužel jsem začátečník, tak nevím jak dál. Používám pro studium knihu od K&R. Díky všem za nápady.
Řešení dotazu:
if ((vstup=fopen("soubor.txt","r")))
{
/* zpracování ... */
fclose(vstup);
}
else
printf("Nelze otevřít soubor pro čtení!\n\a");
if ((vstup=fopen("soubor.txt","r"))) {
if((fgets(pointer,10000000,vstup))==NULL) {
printf("Chyba 1 \n");
}
pointer=druhe_pole;
if((fgets(pointer,10000000,vstup))==NULL) {
printf("Chyba 2 \n");
}
fclose(vstup);
}
else {
printf("Chyba pri otevirani souboru\n\a");
} Váš kód mi fungoval bezproblému, děkuji za něj, bohužel, i když jsem to spravil, nepomohlo to.
pointer, máte tam rezervováno místo pro 10 000 000 bytů (charů) na to dám krk 
#include <stdio.h>
#include <stdlib.h>
#define MY_SIZE (100000)
//main.cpp
int main(int argc, char **argv)
{
char *pointer = NULL;
char *prvni_pole = NULL;
char *druhe_pole = NULL;
if((prvni_pole = (char*) malloc(sizeof(char) * MY_SIZE)) == NULL)
{
printf("Chyba 0-1, nedostatek paměti\n");
exit(3);
}
if((druhe_pole = (char*) malloc(sizeof(char) * MY_SIZE)) == NULL)
{
printf("Chyba 0-2, nedostatek paměti\n");
free(prvni_pole);
exit(3);
}
//aspon
prvni_pole[0] = druhe_pole[0] = 0x0;
//nebo cela alokovana pamet:
//memset(prvni_pole,0x0,MY_SIZE);
//memset(druhe_pole,0x0,MY_SIZE);
FILE *vstup;
if ((vstup=fopen("soubor.txt","r")) == NULL) {
printf("Chyba pri otevirani souboru\n");
exit(3);
}
//ukazatel na první pole i když se m;že použít přímo prvni_pole
pointer = prvni_pole;
if((fgets(pointer,MY_SIZE,vstup))==NULL) {
printf("Chyba 1 \n");
}
if(feof(vstup)){
printf("Chyba uz tam teho vice není\n");
}
else
{
//ukazatel na druhe pole i když se může použít přímo druhe_pole
pointer=druhe_pole;
if((fgets(pointer,MY_SIZE,vstup))==NULL) {
printf("Chyba 2 \n");
}
}
//obvykle netestuje návratovou hodnotu
fclose(vstup);
printf("prvni_pole: %s\n",prvni_pole);
printf("druhe_pole: %s\n",druhe_pole);
//neuskodi
pointer=NULL;
if(prvni_pole != NULL)//fcil zbytecne
free(prvni_pole);
//mozna dobry navyk
prvni_pole=NULL;
if(druhe_pole != NULL)//fcil zbytecne
free(druhe_pole);
//mozna dobry navyk
druhe_pole=NULL;
return 0;
}
char prvni_pole[MY_SIZE];? Dynamicke alokaci se snazi clovek co nejvice vyhnout...
Proc proboha alokujes pole dynamicky?Protože 20MB (dle původního dotazu) nechci jinak.
Dynamicka alokace je mnohem pomalejsi, nez staticka.Rozdíl rychlosti alokace bude neměřitelný a výsledek možná opačný pokud proměnné budou mimo fci main.
Co ti brani v tom, pouzit…Brání mi rozum a ohled na ostatní.
Dynamicke alokaci se snazi clovek co nejvice vyhnout...Dle této definice nejsem člověk
(nebudu se ji vyhýbat za každou cenu), ale vidím to spíše tak, že rozumný programátor použijte to, co je v daném případě lepší a ví kde a jak se, která „rezervace paměti“ provádí…
FILE *fp;
if ((fp = fopen("myfile", "r")) == NULL ) {
perror("unable to open file");
return -1;
}
/* praca so suborom a nasledne close */
fclose(fp);
return 0;
pri uceni je vhodne pouzit aj debugger, napriklad gdb. google ti da vela quick howto ako co .. v tvojom pripadne napriklad:
$ gcc -g -o atest test.c
$ ./atest
attempt to close empty null handle
Segmentation fault: 11 (core dumped)
$
$ gdb ./atest atest.core
GNU gdb 6.1.1 [FreeBSD]
--[snip]--
(gdb) where
#0 0x0000000800719e37 in fclose () from /lib/libc.so.7
#1 0x0000000000400686 in main () at test.c:8
(gdb) list 8
3 int main() {
4 FILE *p_f = fopen("soubor.txt","r+");
5
6 if(p_f == NULL ) {
7 fprintf(stderr, "attempt to close empty null handle\n");
--- vystup z where -> 8 fclose(p_f);
9 }
10
11 return 0;
12 }
kde atest je tvoj spustitelny program, core file sa vygeneroval po segfaulte.
Tiskni
Sdílej: