Desktopové prostředí Budgie bylo vydáno ve verzi 10.10. Dokončena byla migrace z X11 na Wayland. Budgie 10 vstupuje do režimu údržby. Vývoj se přesouvá k Budgie 11. Dlouho se řešilo, v čem bude nové Budgie napsáno. Budgie 10 je postaveno nad GTK 3. Přemýšlelo se také nad přepsáním z GTK do EFL. Budgie 11 bude nakonec postaveno nad Qt 6.
OpenChaos.dev je 'samovolně se vyvíjející open source projekt' s nedefinovaným cílem. Každý týden mohou lidé hlasovat o návrzích (pull requestech), přičemž vítězný návrh se integruje do kódu projektu (repozitář na GitHubu). Hlasováním je možné změnit téměř vše, včetně tohoto pravidla. Hlasování končí vždy v neděli v 9:00 UTC.
Byl vydán Debian 13.3, tj. třetí opravná verze Debianu 13 s kódovým názvem Trixie a Debian 12.13, tj. třináctá opravná verze Debianu 12 s kódovým názvem Bookworm. Řešeny jsou především bezpečnostní problémy, ale také několik vážných chyb. Instalační média Debianu 13 a Debianu 12 lze samozřejmě nadále k instalaci používat. Po instalaci stačí systém aktualizovat.
Na stránkách Evropské komise, na portálu Podělte se o svůj názor, se lze do 3. února podělit o názor k iniciativě Evropské otevřené digitální ekosystémy řešící přístup EU k otevřenému softwaru.
Společnost Kagi stojící za stejnojmenným placeným vyhledávačem vydala (𝕏) alfa verzi linuxové verze (flatpak) svého proprietárního webového prohlížeče Orion.
Firma Bose se po tlaku uživatelů rozhodla, že otevře API svých chytrých reproduktorů SoundTouch, což umožní pokračovat v jejich používání i po plánovaném ukončení podpory v letošním roce. Pro ovládání také bude stále možné využívat oficiální aplikaci, ale už pouze lokálně bez cloudových služeb. Dokumentace API dostupná zde (soubor PDF).
Jiří Eischmann se v příspěvku na svém blogu rozepsal o open source AdGuard Home jako domácí ochraně nejen před reklamou. Adguard Home není plnohodnotným DNS resolverem, funguje jako DNS forwarder s možností filtrování. To znamená, že když přijme DNS dotaz, sám na něj neodpoví, ale přepošle ho na vybraný DNS server a odpovědi zpracovává a filtruje dle nastavených pravidel a následně posílá zpět klientům. Dá se tedy používat k blokování reklamy a škodlivých stránek a k rodičovské kontrole na úrovni DNS.
AI Claude Code od Anthropicu lépe rozumí frameworku Nette, tj. open source frameworku pro tvorbu webových aplikací v PHP. David Grudl napsal plugin Nette pro Claude Code.
Byla vydána prosincová aktualizace aneb nová verze 1.108 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.108 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.
Na lasvegaském veletrhu elektroniky CES byl předveden prototyp notebooku chlazeného pomocí plazmových aktuátorů (DBD). Ačkoliv se nejedná o první nápad svého druhu, nepochybně to je první ukázka praktického použití tohoto způsobu chlazení v běžné elektronice. Co činí plazmové chladící akční členy technologickou výzvou je především vysoká produkce jedovatého ozonu, tu se prý podařilo firmě YPlasma zredukovat dielektrickou
… více »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: