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 17:11 | IT novinky

    Proběhla hackerská soutěž Pwn2Own Ireland 2025. Celkově bylo vyplaceno 1 024 750 dolarů za 73 unikátních zranitelností nultého dne (0-day). Vítězný Summoning Team si odnesl 187 500 dolarů. Shrnutí po jednotlivých dnech na blogu Zero Day Initiative (1. den, 2. den a 3. den) a na YouTube.

    Ladislav Hagara | Komentářů: 1
    dnes 13:33 | Komunita

    Byl publikován říjnový přehled dění a novinek z vývoje Asahi Linuxu, tj. Linuxu pro Apple Silicon. Pracuje se na podpoře M3. Zanedlouho vyjde Fedora Asahi Remix 43. Vývojáře lze podpořit na Open Collective a GitHub Sponsors.

    Ladislav Hagara | Komentářů: 0
    včera 15:44 | Zajímavý software

    Iniciativa Open Device Partnership (ODP) nedávno představila projekt Patina. Jedná se o implementaci UEFI firmwaru v Rustu. Vývoj probíhá na GitHubu. Zdrojové kódy jsou k dispozici pod licencí Apache 2.0. Nejnovější verze Patiny je 13.0.0.

    Ladislav Hagara | Komentářů: 0
    včera 05:11 | Zajímavý článek

    Obrovská poptávka po plynových turbínách zapříčinila, že datová centra začala používat v generátorech dodávajících energii pro provoz AI staré dobré proudové letecké motory, konvertované na plyn. Jejich výhodou je, že jsou menší, lehčí a lépe udržovatelné než jejich průmyslové protějšky. Proto jsou ideální pro dočasné nebo mobilní použití.

    karkar | Komentářů: 7
    24.10. 19:55 | Nová verze

    Typst byl vydán ve verzi 0.14. Jedná se o rozšiřitelný značkovací jazyk a překladač pro vytváření dokumentů včetně odborných textů s matematickými vzorci, diagramy či bibliografií.

    Ladislav Hagara | Komentářů: 0
    24.10. 13:33 | Bezpečnostní upozornění

    Specialisté společnosti ESET zaznamenali útočnou kampaň, která cílí na uživatele a uživatelky v Česku a na Slovensku. Útočníci po telefonu zmanipulují oběť ke stažení falešné aplikace údajně od České národní banky (ČNB) nebo Národní banky Slovenska (NBS), přiložení platební karty k telefonu a zadání PINu. Malware poté v reálném čase přenese data z karty útočníkovi, který je bezkontaktně zneužije u bankomatu nebo na platebním terminálu.

    Ladislav Hagara | Komentářů: 19
    24.10. 13:22 | Upozornění

    V Ubuntu 25.10 byl balíček základních nástrojů gnu-coreutils nahrazen balíčkem rust-coreutils se základními nástroji přepsanými do Rustu. Ukázalo se, že nový "date" znefunkčnil automatickou aktualizaci. Pro obnovu je nutno balíček rust-coreutils manuálně aktualizovat.

    Ladislav Hagara | Komentářů: 13
    24.10. 04:55 | Komunita

    VST 3 je nově pod licencí MIT. S verzí 3.8.0 proběhlo přelicencování zdrojových kódů z licencí "Proprietary Steinberg VST3 License" a "General Public License (GPL) Version 3". VST (Virtual Studio Technology, Wikipedie) je softwarové rozhraní pro komunikaci mezi hostitelským programem a zásuvnými moduly (pluginy), kde tyto moduly slouží ke generování a úpravě digitálního audio signálu.

    Ladislav Hagara | Komentářů: 1
    24.10. 03:22 | Nová verze

    Open source 3D herní a simulační engine Open 3D Engine (O3DE) byl vydán v nové verzi 25.10. Podrobný přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    23.10. 20:11 | Komunita

    V Londýně probíhá dvoudenní Ubuntu Summit 25.10. Na programu je řada zajímavých přednášek. Zhlédnout je lze také na YouTube (23. 10. a 24. 10.).

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (36%)
     (48%)
     (20%)
     (20%)
     (23%)
     (17%)
     (20%)
     (17%)
     (18%)
    Celkem 274 hlasů
     Komentářů: 14, poslední 14.10. 09:04
    Rozcestník

    Dotaz: Únik paměti v C

    31.10.2021 00:39 NIC5
    Únik paměti v C
    Přečteno: 466×
    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× (Gréta, В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
    Gréta avatar 31.10.2021 11:09 Gréta | skóre: 37 | 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

    Gréta avatar 31.10.2021 11:16 Gréta | skóre: 37 | 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× (Gréta)
    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× (Gréta)
    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.