Byla vydána nová verze 4.4 multiplatformního integrovaného vývojového prostředí (IDE) pro rychlý vývoj aplikaci (RAD) ve Free Pascalu Lazarus (Wikipedie). Využíván je Free Pascal Compiler (FPC) 3.2.2.
ASUS má v nabídce komplexní řešení pro vývoj a nasazení AI: kompaktní stolní AI superpočítač ASUS Ascent GX10 poháněný superčipem NVIDIA GB10 Grace Blackwell a platformou NVIDIA DGX Spark. S operačním systémem NVIDIA DGX založeném na Ubuntu.
Desktopové prostredie Trinity Desktop vyšlo vo verzii R14.1.5. Je tu opravená chyba v tqt komponente spôsobujúca 100% vyťaženie cpu, dlaždice pre viac monitorov a nemenej dôležité su dizajnové zmeny v podobe ikon, pozadí atď. Pridaná bola podpora distribúcií Debian Trixie, Ubuntu Questing, RHEL 10 a OpenSUSE Leap 16.
Grafická aplikace Easy Effects (Flathub), původně PulseEffects, umožňující snadno povolovat a zakazovat různé audio efekty v aplikacích používajících multimediální server PipeWire, byla vydána ve verzi 8.0.0. Místo GTK 4 je nově postavená nad Qt, QML a Kirigami.
Na YouTube lze zhlédnout Godot Engine – 2025 Showreel s ukázkami toho nejlepšího letos vytvořeného v multiplatformním open source herním enginu Godot.
Blíží se konec roku a tím i všemožná vyhlášení slov roku 2025. Dle Collins English Dictionary je slovem roku vibe coding, dle Dictionary.com je to 6-7, …
Cloudflare Radar: podíl Linuxu na desktopu dosáhl v listopadu 6,2 %.
Chcete vědět, co se odehrálo ve světě techniky za poslední měsíc? Nebo si popovídat o tom, co zrovna bastlíte? Pak doražte na listopadovou Virtuální Bastlírnu s mikrofonem a kamerou, nalijte si něco k pití a ponořte se s strahovskými bastlíři do diskuze u virtuálního piva o technice i všem možném okolo. Mezi nejvýznamnější novinky patří Průšovo oznámení Core One L, zavedení RFID na filamentech, tisk silikonu nebo nový slicer. Dozvíte se ale i
… více »Vývojáři OpenMW (Wikipedie) oznámili vydání verze 0.50.0 této svobodné implementace enginu pro hru The Elder Scrolls III: Morrowind. Přehled novinek i s náhledy obrazovek v oznámení o vydání.
Komunita kolem Linux Containers po roce vývoje představila (YouTube) neměnný operační systém IncusOS speciálně navržený pro běh Incusu, tj. komunitního forku nástroje pro správu kontejnerů LXD. IncusOS poskytuje atomické aktualizace prostřednictvím mechanismu A/B aktualizací s využitím samostatných oddílů a vynucuje zabezpečení bootování pomocí UEFI Secure Bootu a modulu TPM 2.0. Postaven je na Debianu 13.
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: