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 01:33 | Nová verze

    Organizace Apache Software Foundation (ASF) vydala verzi 28 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.

    Ladislav Hagara | Komentářů: 0
    včera 16:11 | Nová verze

    Byl vydán Debian 13.2, tj. druhá opravná verze Debianu 13 s kódovým názvem Trixie. Řešeny jsou především bezpečnostní problémy, ale také několik vážných chyb. Instalační média Debianu 13 lze samozřejmě nadále k instalaci používat. Po instalaci stačí systém aktualizovat.

    Ladislav Hagara | Komentářů: 0
    včera 12:11 | IT novinky

    Google představil platformu Code Wiki pro rychlejší porozumění existujícímu kódu. Code Wiki pomocí AI Gemini udržuje průběžně aktualizovanou strukturovanou wiki pro softwarové repozitáře. Zatím jenom pro veřejné. V plánu je rozšíření Gemini CLI také pro soukromé a interní repozitáře.

    Ladislav Hagara | Komentářů: 3
    14.11. 14:22 | Bezpečnostní upozornění

    V přihlašovací obrazovce LightDM KDE (lightdm-kde-greeter) byla nalezena a již opravena eskalace práv (CVE-2025-62876). Detaily v příspěvku na blogu SUSE Security.

    Ladislav Hagara | Komentářů: 5
    14.11. 13:22 | Nová verze

    Byla vydána nová verze 7.2 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Tor Browser byl povýšen na verzi 15.0.1. Další novinky v příslušném seznamu.

    Ladislav Hagara | Komentářů: 0
    14.11. 10:33 | IT novinky

    Česká národní banka (ČNB) nakoupila digitální aktiva založená na blockchainu za milion dolarů (20,9 milionu korun). Na vytvořeném testovacím portfoliu, jehož součástí jsou bitcoin, stablecoiny navázané na dolar a tokenizované depozitum, chce získat praktickou zkušenost s držením digitálních aktiv. Portfolio nebude součástí devizových rezerv, uvedla dnes ČNB v tiskové zprávě.

    Ladislav Hagara | Komentářů: 41
    14.11. 03:22 | IT novinky

    Apple představil iPhone Pocket pro stylové přenášení iPhonu. iPhone Pocket vzešel ze spolupráce značky ISSEY MIYAKE a Applu a jeho tělo tvoří jednolitý 3D úplet, který uschová všechny modely iPhonu. iPhone Pocket s krátkým popruhem se prodává za 149,95 dolarů (USA) a s dlouhým popruhem za 229,95 dolarů (USA).

    Ladislav Hagara | Komentářů: 17
    14.11. 02:33 | Nová verze

    Byla vydána nová stabilní verze 7.7 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 142. Přehled novinek i s náhledy v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    13.11. 22:11 | Nová verze

    Společnost Epic Games vydala verzi 5.7 svého proprietárního multiplatformního herního enginu Unreal Engine (Wikipedie). Podrobný přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 2
    13.11. 16:22 | Bezpečnostní upozornění

    Intel vydal 30 upozornění na bezpečnostní chyby ve svých produktech. Současně vydal verzi 20251111 mikrokódů pro své procesory.

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (35%)
     (47%)
     (18%)
     (18%)
     (23%)
     (15%)
     (23%)
     (16%)
     (16%)
    Celkem 354 hlasů
     Komentářů: 16, poslední 12.11. 18:21
    Rozcestník

    Dotaz: Memory leak v stl?

    19.12.2008 12:10 esparky
    Memory leak v stl?
    Přečteno: 509×

    Dobrý den, v mém projektu mě trápí dost protivný memory leak, při jehož hledání jsem došel zhruba k následující konstrukci, která jej způsobuje:

    #include <map>
    #include <string>
    #include <iostream>
    #include <stdio.h>
    #include <sstream>
    using namespace std;

    multimap<int,string> mapa;

    int main() {
        for(int i=0;i<20000;i++) {
            stringstream s;
            mapa.insert(make_pair(i%234,string("fdsfdsfdsfdsfdsfds")+s.str()));
        };
        cout<<"Mapa vytvorena"<<endl;

        getc(stdin);  //Zde celý program zabírá 2292 KB

        cout<<"Jdu mazat"<<endl;

        for(int i=0;i<234;++i) {
            mapa.erase(i);
        };
        cout<<"smazano"<<mapa.size()<<endl;

        getc(stdin); //Zde program zabírá 2312KB
    };

     

    Zajímalo by mě, proč na konci programu je stále naalokováno tolik paměti, i když mapa neobsahuje žádné záznamy. Zabranou pamět zjišťuji příkazem ps s parametrem RSS. Valgrind žádný leak neukazuje.

    Stejný problém jsem narazil i u vectoru, a asi bude i u dalších kontejnerů.

    Máte pro to nějaké vysvětlení? Lze nějak přikázat kontejneru/překladači, aby paměť skutečně delalokoval?

    Odpovědi

    19.12.2008 12:34 graviton
    Rozbalit Rozbalit vše Re: Memory leak v stl?
    http://valgrind.org/docs/manual/faq.html#faq.reports
    19.12.2008 12:52 blondak | skóre: 36 | blog: Blondak | Čáslav
    Rozbalit Rozbalit vše Re: Memory leak v stl?

    Tak nevím. ale přijde mi, že alokujete 20000 členů a pak uvolníte jenom 234, nemůže být problém tam?

    Každý problém ma své logické, snadno pochopitelné nesprávné řešení.
    19.12.2008 12:59 blondak | skóre: 36 | blog: Blondak | Čáslav
    Rozbalit Rozbalit vše Re: Memory leak v stl?

    beru zpět přehlídnul jsem tam to %234 :(

    Každý problém ma své logické, snadno pochopitelné nesprávné řešení.
    Luboš Doležel (Doli) avatar 19.12.2008 13:45 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
    Rozbalit Rozbalit vše Re: Memory leak v stl?
    Podívejte se, co vám vrátí std::vector<T>::capacity() - tam se to asi bude skrývat. Napadá mě leda zkusit clear(), ale nevím nevím.
    19.12.2008 14:56 karl82 | skóre: 6
    Rozbalit Rozbalit vše Re: Memory leak v stl?
    20.12.2008 01:43 luky
    Rozbalit Rozbalit vše Re: Memory leak v stl?
    Alokátor při mazání objektů (myšleno obecně jako bloky paměti, ne nutně jako instance tříd apod.) typicky nevrací všechnu volnou paměť zpátky systému, aby měl něco v rezervě pro další alokace a nemusel od systému hned žádat novou. Jestli to jde nějak vynutit (standardními funkcemi C++/STL) netuším, ale nelámal bych si s tím hlavu.
    20.12.2008 19:37 puk
    Rozbalit Rozbalit vše Re: Memory leak v stl?

    Je mozny vyhradit urcitou kapacitu: std::vector(int) vec, vec.reseve(10); aby nedochazelo k realokaci behem plneni. Pokud uz mame plnej vektor a chceme jej zmensit na pocet (size()), pak zavolame std::vector<int>(vec).swap(vec);

    20.12.2008 23:19 Martin Doucha | skóre: 23 | blog: Yet another blog
    Rozbalit Rozbalit vše Re: Memory leak v stl?

    To není memory leak, STL je prostě žrout paměti. Co kontejner schvátí, jen tak nevrátí ;-)

    21.12.2008 00:21 esparky
    Rozbalit Rozbalit vše Re: Memory leak v stl?

    Děkuji všem za odpověďi To %234, tam je pouze, abych měl v kontejneru různé prvky, z nichž některé se budou opakovat. Nechtěl jsem tím mást:) Opravdu je to tak, že STL si naalokuje paměť a tu potom používá, takže v pokud pole znovu naplním, nová paměť už se nebere...ale pouze na tomhle testovacím prográmku, v mém projektu ne :'(. Zajímalo by mě, zda existuje možnost, jak přinutit SDL aby tu paměť dealokoval (clear() nepomáhá). Zkoušel jsem to exportnutí GLIBCXX_FORCE_NEW, ale nepomáhá to. Nějaká cesta, jak přinutit SDL dealokovat paměť přece musí existovat, protože jinak by jakýkoli program - deamon, co třeba při spuštění potřebuje 100MB RAM a pak už jen 2MB žral celou dobu 100 paměti...to by přece nikdo nemohl přehlédnout:)

    21.12.2008 11:56 Boris Dušek | skóre: 22 | blog: everything
    Rozbalit Rozbalit vše Re: Memory leak v stl?

     GLIBCXX_FORCE_NEW je určitě těžce nepřenositelné. Řešení ti popsal "puk" o pár příspěvků výše (aneb např. string(s).swap(s), obdobně pro vector apod.)

    vim ~/.emacs
    Luboš Doležel (Doli) avatar 21.12.2008 17:04 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
    Rozbalit Rozbalit vše Re: Memory leak v stl?
    Jenže to, co tu předvádíte, je vcelku nestandardní situace. Pokud někdo maže položky z vektoru a už tam nic pak nedává, děje se tak např. před destrukcí celého objektu, kdy se paměť uvolní. A pokud se ten vektor nelikviduje, tak se do něj pravděpodobně zas něco dá. A pokud se vám tenhle alokátor nelíbí, tak použijte/napište jiný,

    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.