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í
×
    13.9. 17:33 | Pozvánky

    Spolek OpenAlt zve příznivce otevřených řešení a přístupu na 211. sraz, který proběhne v pátek 19. září od 18:00 ve Studentském klubu U Kachničky na Fakultě informačních technologií Vysokého učení technického na adrese Božetěchova 2/1. Na srazu proběhne přednáška Jiřího Eischmanna o nové verzi prostředí GNOME 49. Nemáte-li možnost se zúčastnit osobně, přednáškový blok bude opět streamován živě na server VHSky.cz a následně i zpřístupněn záznam.

    Ladislav Hagara | Komentářů: 0
    13.9. 01:33 | IT novinky

    Microsoft se vyhnul pokutě od Evropské komise za zneužívání svého dominantního postavení na trhu v souvislosti s aplikací Teams. S komisí se dohodl na závazcích, které slíbil splnit. Unijní exekutivě se nelíbilo, že firma svazuje svůj nástroj pro chatování a videohovory Teams se sadou kancelářských programů Office. Microsoft nyní slíbil jasné oddělení aplikace od kancelářských nástrojů, jako jsou Word, Excel a Outlook. Na Microsoft si

    … více »
    Ladislav Hagara | Komentářů: 9
    12.9. 14:00 | Nová verze

    Samba (Wikipedie), svobodná implementace SMB a Active Directory, byla vydána ve verzi 4.23.0. Počínaje verzí Samba 4.23 jsou unixová rozšíření SMB3 ve výchozím nastavení povolena. Přidána byla podpora SMB3 přes QUIC. Nová utilita smb_prometheus_endpoint exportuje metriky ve formátu Prometheus.

    Ladislav Hagara | Komentářů: 0
    12.9. 12:00 | Zajímavý článek

    Správcovský tým repozitáře F-Droid pro Android sdílí doporučení, jak řešit žádosti o odstranění nelegálního obsahu. Základem je mít nastavené formální procesy, vyhrazenou e-mailovou adresu a být transparentní. Zdůrazňují také důležitost volby jurisdikce (F-Droid je v Nizozemsku).

    🇵🇸 | Komentářů: 20
    12.9. 05:33 | Bezpečnostní upozornění

    Byly publikovány informace o další zranitelnosti v procesorech. Nejnovější zranitelnost byla pojmenována VMScape (CVE-2025-40300, GitHub) a v upstream Linuxech je již opravena. Jedná se o variantu Spectre. KVM host může číst data z uživatelského prostoru hypervizoru, např. QEMU.

    Ladislav Hagara | Komentářů: 0
    11.9. 22:00 | Komunita

    V červenci loňského roku organizace Apache Software Foundation (ASF) oznámila, že se částečně přestane dopouštět kulturní apropriace a změní své logo. Dnes bylo nové logo představeno. "Indiánské pírko" bylo nahrazeno dubovým listem a text Apache Software Foundation zkratkou ASF. Slovo Apache se bude "zatím" dál používat. Oficiální název organizace zůstává Apache Software Foundation, stejně jako názvy projektů, například Apache HTTP Server.

    Ladislav Hagara | Komentářů: 16
    11.9. 17:33 | Nová verze

    Byla vydána (𝕏) srpnová aktualizace aneb nová verze 1.104 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.104 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 1
    11.9. 15:33 | IT novinky

    Spotify spustilo přehrávání v bezztrátové kvalitě. V předplatném Spotify Premium.

    Ladislav Hagara | Komentářů: 0
    11.9. 15:00 | IT novinky

    Spoluzakladatel a předseda správní rady americké softwarové společnosti Oracle Larry Ellison vystřídal spoluzakladatele automobilky Tesla a dalších firem Elona Muska na postu nejbohatšího člověka světa. Hodnota Ellisonova majetku díky dnešnímu prudkému posílení ceny akcií Oraclu odpoledne vykazovala nárůst o více než 100 miliard dolarů a dosáhla 393 miliard USD (zhruba 8,2 bilionu Kč). Hodnota Muskova majetku činila zhruba 385 miliard dolarů.

    Ladislav Hagara | Komentářů: 11
    10.9. 21:22 | Nová verze

    Bylo vydáno Eclipse IDE 2025-09 aneb Eclipse 4.37. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.

    Ladislav Hagara | Komentářů: 0
    Pro otevření více webových stránek ve webovém prohlížečí používám
     (81%)
     (7%)
     (3%)
     (3%)
     (4%)
     (2%)
    Celkem 179 hlasů
     Komentářů: 12, poslední 10.9. 13:00
    Rozcestník

    Dotaz: Únik paměti v C

    31.10.2021 00:39 NIC5
    Únik paměti v C
    Přečteno: 462×
    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.