abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 04:11 | Nová verze

    Multiplatformní open source aplikace scrcpy (Wikipedie) pro zrcadlení připojeného zařízení se systémem Android na desktopu a umožňující ovládání tohoto zařízení z desktopu, byla vydána v nové verzi 4.0.

    Ladislav Hagara | Komentářů: 0
    včera 23:22 | Pozvánky

    Chybí vám někdo, s kým byste si popovídali o bastlení, technice, počítačích a vědě? Nechcete riskovat debatu o sportu u piva v hospodě? Pak doražte na virtuální pokec u virtuálního piva v rámci Virtuální Bastlírny organizované strahovským MacGyverem již tento čtvrtek. Možná se ptáte, co se tak může probírat? Dají se probrat slavná výročí - kromě 55 let obvodu 555 (což je mimochodem prý andělské číslo) a vzpomínky na firmu Signetics -

    … více »
    bkralik | Komentářů: 0
    včera 23:11 | Zajímavý software

    GTK2-NG je komunitní fork GTK 2.24 (aktuální verze je 4.22). Oznámení a diskuse v diskusním fóru Devuanu, forku Debianu bez systemd. Není to jediný fork GTK 2. Ardour je například postaven na vlastním forku GTK 2 s názvem YTK.

    Ladislav Hagara | Komentářů: 0
    včera 17:33 | Pozvánky

    V neděli 17. května 2026 proběhne v Českých Budějovicích první MobileLinux Hackday zaměřený na Linux v mobilech, embedded platformy a open source hardware. Po sedmi úspěšných měsíčních setkáních v Praze se akce přesouvá také do jižních Čech, aby se komunita mobilního Linuxu mohla potkat i mimo hlavní město. Akce se uskuteční v konferenčním sále Vajgar v Clarion Congress Hotelu (Pražská tř. 2306/14) se zahájením mezi 14:00 až 15:00 a … více »

    lkocman | Komentářů: 0
    včera 15:00 | Komunita

    Vývojáři Debianu zhruba v polovině vývojového cyklu Debianu 14 s kódovým názvem Forky rozhodli, že Debian musí dodávat reprodukovatelné balíčky, tj. kdokoli si může nezávisle ověřit, že daný binární balíček vznikl překladem a sestavením z konkrétních zdrojových kódů. Aktuálně je reprodukovatelných 98,29 % balíčků.

    Ladislav Hagara | Komentářů: 0
    včera 14:11 | Bezpečnostní upozornění

    Německý e-shop Škoda Auto byl hacknut. Útočníci získali přístup k uživatelským údajům (jméno, adresa, e-mail, heslo, telefon, …).

    Ladislav Hagara | Komentářů: 4
    včera 11:22 | Pozvánky

    Na webu konference Den IPv6 2026, která se uskuteční 4. června v Národní technické knihovně v pražských Dejvicích, je nyní k dispozici kompletní program této tradiční akce věnované tématům spojeným s protokolem IPv6. Na celodenní pásmo přednášek je třeba se přihlásit a zaplatit účastnický poplatek 242 korun. Registrační formulář najdou zájemci opět na webu akce. Konferenci Den IPv6 2026 organizují i letos společně sdružení CESNET, CZ.NIC a NIX.CZ.

    VSladek | Komentářů: 1
    11.5. 23:33 | Zajímavý software

    Byl představen emulátor terminálu Ratty (GitHub) s podporu 3D grafiky přímo v terminálu. Inspirací byl operační systém TempleOS od Terryho Davise. Ratty je napsán v jazyce Rust. Využívá knihovnu Ratatui pro tvorbu rozhraní a herní engine Bevy pro 3D vykreslování.

    Ladislav Hagara | Komentářů: 5
    11.5. 17:55 | IT novinky

    Evropské instituce i některé americké státy dál zpřísňují pravidla pro ověřování věku na internetu. Cílem je zabránit dětem v přístupu k obsahu pro dospělé. Úřady ale narážejí na zásadní problém – stále více lidí používá VPN, tedy služby umožňující skrýt identitu i skutečnou polohu na internetu. Právě VPN nyní Evropská parlamentní výzkumná služba (EPRS) označila za „mezeru v legislativě, kterou je potřeba uzavřít“ [Novinky.cz].

    Ladislav Hagara | Komentářů: 43
    11.5. 17:22 | Nová verze

    Multiplatformní open source aplikace pro psaní poznámek Joplin (Wikipedie) byla vydána v nové verzi 3.6. Nově lze mít v poznámkách embedovaný externí obsah, např. YouTube videa.

    Ladislav Hagara | Komentářů: 4
    Které desktopové prostředí na Linuxu používáte?
     (13%)
     (9%)
     (2%)
     (14%)
     (31%)
     (4%)
     (7%)
     (3%)
     (16%)
     (25%)
    Celkem 1593 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: Únik paměti v C

    31.10.2021 00:39 NIC5
    Únik paměti v C
    Přečteno: 493×
    Příloha:
    Dobrý den, měl bych dotaz ohledně úniku paměti v programu. Nevíte někdo, jak vyřešit paměť, aby se tohle nestalo. Děkuji za rady.

    int lencln(char const * sin){ int len = 0;

    for (int i = 0; sin[i] != '\0'; i++) { if(sin[i] >= 'A' && sin[i] <= 'Z' || sin[i] >= 'a' && sin[i] <= 'z'){ len++; } }

    return len; }

    char * clean(char const * sin){ int j = 0; char * str_cln = NULL;

    str_cln = (char*)malloc(sizeof(char) * (lencln(sin) + 1));

    if(!str_cln){ fprintf(stderr, "Out of memory!\n"); exit(-10); }

    for (int i = 0; sin[i] != '\0'; i++) { if(sin[i] >= 'A' && sin[i] <= 'Z' || sin[i] >= 'a' && sin[i] <= 'z'){ str_cln[j] = sin[i]; j++; } }

    return str_cln; }

    int main(){ char sin[101];

    scanf(" %100[^\n]s", sin);

    char * strout = clean(sin);

    printf("%s\n", strout);

    free(strout); strout = NULL;

    return 0; }

    Řešení dotazu:


    Odpovědi

    Řešení 1× (candat)
    31.10.2021 01:02 meakunda
    Rozbalit Rozbalit vše Re: Únik paměti v C
    Ahoj, přepiš to do rustu, c už dnes nikdo nepoužívá právě z tohoto důvodu, nejde to zabezpečit.
    Řešení 2× (MakeIranBombedAgain❗, Вherzet)
    31.10.2021 01:07 z_sk | skóre: 34 | blog: analyzy
    Rozbalit Rozbalit vše Re: Únik paměti v C
    Viď riadok č. 28.
    #include <stdio.h>
    #include <stdlib.h>
    
    int lencln(char const * sin)
    {
    	int len = 0;
    
    	for (int i = 0; sin[i] != '\0'; i++)
    		if((sin[i] >= 'A' && sin[i] <= 'Z') || (sin[i] >= 'a' && sin[i] <= 'z'))
    			len++;
    
    	return len;
    }
    
    char * clean(char const * sin){
    	
    	int j = 0;
    	char *str_cln = NULL;
    
    	str_cln = (char*) malloc(sizeof(char) * (lencln(sin) + 1));
    	if(str_cln == NULL)
    		return NULL;
    
    	for (int i = 0; sin[i] != '\0'; i++)
    		if((sin[i] >= 'A' && sin[i] <= 'Z') || (sin[i] >= 'a' && sin[i] <= 'z'))
    			str_cln[j++] = sin[i];
    
    	str_cln[j]='\0'; // !!!
    
    	return str_cln;
    }
    
    int main(){
    	char sin[101];
    	
    	scanf(" %100[^\n]s", sin);
    
    	char * strout = clean(sin);
    
    	puts(strout);
    
    	free(strout);
    	strout = NULL;
    	
    	return 0;
    }
    
    
    A ten Tvoj obrázok je výstup z akého programu?
    debian.plus@protonmail.com
    MakeIranBombedAgain❗ avatar 31.10.2021 11:09 MakeIranBombedAgain❗ | skóre: 42 | blog: Grétin blogísek | 🇮🇱==❤️ , 🇵🇸==💩 , 🇪🇺==☭
    Rozbalit Rozbalit vše Re: Únik paměti v C

    A ten Tvoj obrázok je výstup z akého programu?

    z toho samýho jeho zkompilovanýho :O ;D hele jendův tutorial na asan ;D

    MakeIranBombedAgain❗ avatar 31.10.2021 11:16 MakeIranBombedAgain❗ | skóre: 42 | blog: Grétin blogísek | 🇮🇱==❤️ , 🇵🇸==💩 , 🇪🇺==☭
    Rozbalit Rozbalit vše Re: Únik paměti v C

    .......obrázok..

    btw text z konzole si mužeš normálně zkopírovat když ho uplně vobyčejně voznačíš myšičkou a pak máčkneš ctrl+shift+c a nemusíš čarovat s vobrázkama :O ;D ......a mužeš taky líp poskovávat jakejže soubor kde kompiluješ by tě učitelskej nemoch doxnout :O :D ;D ;D

    podobně ctrl+shift+v na vložení textu do terminálu :O ;D

    Řešení 1× (MakeIranBombedAgain❗)
    Jendа avatar 31.10.2021 04:43 Jendа | skóre: 78 | blog: Jenda | JO70FB
    Rozbalit Rozbalit vše Re: Únik paměti v C
    Dej kód do <pre>, tohle je na prd.

    Nějak jsem to otipoval a hned při kompilaci vyletí warning:
    a.c: In function ‘lencln’:
    a.c:8:22: warning: suggest parentheses around ‘&&’ within ‘||’ [-Wparentheses]
        8 |     if(sin[i] >= 'A' && sin[i] <= 'Z' || sin[i] >= 'a' && sin[i] <= 'z'){
          |        ~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~
    a.c: In function ‘clean’:
    a.c:23:22: warning: suggest parentheses around ‘&&’ within ‘||’ [-Wparentheses]
       23 |     if(sin[i] >= 'A' && sin[i] <= 'Z' || sin[i] >= 'a' && sin[i] <= 'z') {
          |        ~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~
    
    tak bych začal tím. Dále bývá zvykem přiložit vstup, na kterém to spadne (např. jestli když tady testuješ písmenka, tak musí mít vstup čísla nebo tak něco), ale naštěstí mi to spadlo na prvním co jsem zadal.

    A ta chyba je podle mě v tom, že alokuješ str_cln mallocem (neinicializované), nikde do toho nenapíšeš terminující nulu a pak se to pokusíš printfnout. No a printf čte a čte a čte, až narazí na konec. Takže tam přidej na konec clean str_cln[j] = 0; nebo alokuj callocem, ten ti to vynuluje.

    Plus dávám za použití satanizéru, který zjevně alokovanou paměť otravuje, protože když to zkompiluju bez něj, tak mi většinou malloc vrátí nuly (byť podle specifikace tam může být cokoli), protože heap je na začátku vynulovaný aby tam nebyla tajná data předchozích procesů, a chyba se tak hned neprojeví.
    Řešení 1× (MakeIranBombedAgain❗)
    Jendа avatar 31.10.2021 04:46 Jendа | skóre: 78 | blog: Jenda | JO70FB
    Rozbalit Rozbalit vše Re: Únik paměti v C
    Tady je komiks kde mají přesně ten tvůj problém.
    31.10.2021 09:56 NIC5
    Rozbalit Rozbalit vše Re: Únik paměti v C
    Vyřešeno. Bylo to v tom '\0', jak jste radili.
    31.10.2021 09:57 NIC5
    Rozbalit Rozbalit vše Re: Únik paměti v C
    Vyřešeno. Bylo to v tom "\0", jak jste radili.

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.