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 14:44 | IT novinky

    Na lepší pokrytí mobilním signálem a dostupnější mobilní internet se mohou těšit cestující v Pendolinech, railjetech a InterPanterech Českých drah. Konsorcium firem ČD - Telematika a.s. a Kontron Transportation s.r.o. dokončilo instalaci 5G opakovačů mobilního signálu do jednotek Pendolino a InterPanter. Tento krok navazuje na zavedení této technologie v jednotkách Railjet z letošního jara.

    Ladislav Hagara | Komentářů: 0
    dnes 12:22 | Bezpečnostní upozornění

    Rozšíření webového prohlížeče Urban VPN Proxy a další rozšíření od stejného vydavatele (např. 1ClickVPN Proxy, Urban Browser Guard či Urban Ad Blocker) od července 2025 skrytě zachytávají a odesílají celé konverzace uživatelů s AI nástroji (včetně ChatGPT, Claude, Gemini, Copilot aj.), a to nezávisle na tom, zda je VPN aktivní. Sběr probíhá bez možnosti jej uživatelsky vypnout a zahrnuje plný obsah dotazů a odpovědí, metadata relací i

    … více »
    Ladislav Hagara | Komentářů: 3
    dnes 05:22 | Zajímavý software

    QStudio, tj. nástroj pro práci s SQL podporující více než 30 databází (MySQL, PostgreSQL, DuckDB, QuestDB, kdb+, …), se stal s vydáním verze 5.0 open source. Zdrojové kódy jsou k dispozici na GitHubu pod licencí Apache 2.0.

    Ladislav Hagara | Komentářů: 2
    dnes 04:55 | Nová verze

    Byla vydána nová verze 259 správce systému a služeb systemd (Wikipedie, GitHub).

    Ladislav Hagara | Komentářů: 0
    dnes 02:55 | Zajímavý článek

    Cloudflare Radar poskytuje aktuální informace o globálním internetovém provozu, útocích nebo trendech. Publikován byl celkový přehled za rok 2025. Globální internetový provoz vzrostl v roce 2025 o 19 %.

    Ladislav Hagara | Komentářů: 0
    včera 15:22 | IT novinky

    Správní rada americké mediální skupiny Warner Bros. Discovery (WBD) podle očekávání odmítla nepřátelskou nabídku na převzetí od firmy Paramount Skydance za 108,4 miliardy dolarů (2,25 bilionu Kč). Paramount podle ní neposkytl dostatečné finanční záruky. Akcionářům proto doporučuje nabídku od Netflixu.

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

    Na WhatsAppu se šíří nový podvod, který ovšem vůbec nevypadá jako hackerský útok. Žádná krádež hesla. Žádné narušení zabezpečení. Žádné zjevné varovné signály. Místo toho jsou lidé trikem donuceni, aby útočníkům sami poskytli přístup, a to pouhým provedením toho, co vypadá jako běžný ověřovací krok. Bezpečnostní experti Avastu tento nový typ útoku nazývají ghostpairing, protože útočníci si při něm tiše vytvářejí „zařízení duchů“, které žije uvnitř vašeho účtu.

    Ladislav Hagara | Komentářů: 4
    včera 12:33 | Nová verze

    Český LibreOffice tým vydává aktualizaci překladu příručky LibreOffice Draw 25.8. Tato kniha se zabývá hlavními funkcemi programu Draw, vektorové grafické komponenty systému LibreOffice. Pomocí Draw lze vytvářet širokou škálu grafických obrázků. Příručka je ke stažení na stránce dokumentace a tým hledá dobrovolníky pro další překlady.

    ZCR | Komentářů: 1
    včera 04:00 | IT novinky

    Anthony Enzor-DeMeo je novým CEO Mozilla Corporation. Mozillu převzal po dočasné CEO Lauře Chambers. Vybudovat chce nejdůvěryhodnější softwarovou společnost na světě. Firefox by se měl vyvinout v moderní AI prohlížeč.

    Ladislav Hagara | Komentářů: 8
    16.12. 17:11 | Nová verze

    Byla vydána nová verze 9.20 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Přehled novinek v poznámkách k vydání. Vypíchnout lze například nový balíček RustDesk Server pro vzdálený přístup.

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (35%)
     (48%)
     (20%)
     (17%)
     (23%)
     (15%)
     (24%)
     (16%)
     (17%)
    Celkem 482 hlasů
     Komentářů: 19, poslední 11.12. 20:04
    Rozcestník

    Dotaz: Linearny zoznam c++

    Xgamer avatar 8.3.2011 15:23 Xgamer | skóre: 4
    Linearny zoznam c++
    Přečteno: 568×
    Zdravím už zopár dní bojujem zo zadaním z C++. A už som fakt zúfalý :( Mojou ulohou je dorobiť danú šablonu. Tu su zdrojáky:

    main.c
    #include < iostream >
    #include "cList.h"
    using namespace std;
    
    int main()
    {
        cout << "Linked List" << endl;
        cout << "--------------" << endl;
        cNode* n1 = new cNode("1");
        cNode* n2 = new cNode("2");
        cNode* n3 = new cNode("3");
    
        cList zoznam;
        zoznam.append(n1);
        zoznam.append(n2);
        zoznam.append(n3);
        zoznam.append(new cNode(*n1));
        zoznam.append(new cNode(*n1));
        zoznam.append(new cNode(*n1));
        zoznam.printContents();
    
        cNode* n4 = new cNode("4");
        cNode* n2_5 = new cNode("2.5");
        zoznam.insert(n4, 10);
        zoznam.insert(n2_5, 2);
        zoznam.deleteNode(1);
        zoznam.deleteNode(0);
        zoznam.deleteNode(10);
        cout<<"---------------------------"<< endl;
        zoznam.printContents();
    
        cList zoznam2 = cList(zoznam);
        zoznam2.deleteNode(0);
        zoznam2.deleteNode(0); // nezmaže mi nultý prvok vidim to na problem s kopirovacím konštruktorom
        cout<<"------------Zoznam 1 - original---------------"<< endl;
        zoznam.printContents();
        cout<<"------------Zoznam 2 - kopia---------------"<< endl;
        zoznam2.printContents();
    
       delete n1; // hádže segmantation fault
       delete n2;
       delete n3;
       delete n4;
       delete n2_5;
    
        return 0;
    }
    [/code]
    
    Problémový kod z cList.cpp 
    
    [code]#include "cList.h"
    
    using namespace std;
    cList::cList()
    {
        first = NULL;
    }
    
    cList::cList(const cList &oldList) // kopíruje aj to čo už nemá byť v pamäti, predpokladám že preto mi nemaže to čo by malo 
    {
    
        first = NULL;
    
        if (oldList.getLength() > 0)
        {
            first = new cNode(oldList.first->getData());
    
            cNode *tmp = first, *tmp2;
    
            for (int i = 0; i < oldList.getLength(); i++)
            {
                tmp2 = new cNode(oldList.getNode(i)->getData());
    
                tmp->setNext(tmp2);
    
                tmp = tmp2;
            }
        }
    }
    
    cList::~cList() // tento deštruktor asi sposobuje segmentation fault
    {
        for(int i = 0;i < getLength();i++)
        {
            cNode *tmp = getNode(i); // funkcie getNode vráti uzol na danom indexe, funguje v iných častiach kodu, v nej by problem byť nemal
            delete tmp;
        }
        delete first;
    }
    Ostatne časti kodu zatial nebudem posielať.. . Som si na 99% istý že problem je v tomto kode. Pridal som do zdrojaku komentáre že čo nefunguje. Pri kopirovaní celeho zoznamu sa skopiruje aj to čo by tam už nemalo byť neviem prečo:( V tom deštruktore idem asi zle na to uvolnovanie pamäte.. ale zase keď nemam v tom deštruktore nič tak mi to počas delete sekcie v main.c vypiš random vypis pamäte... Ďakujem :)

    Řešení dotazu:


    Odpovědi

    8.3.2011 17:03 Sten
    Rozbalit Rozbalit vše Re: Linearny zoznam c++
    Není náhodou getNode(0) to samé, co first? Protože jinak ho kopírujete a mažete dvakrát.
    Řešení 1× (Xgamer (tazatel))
    Xgamer avatar 8.3.2011 17:18 Xgamer | skóre: 4
    Rozbalit Rozbalit vše Re: Linearny zoznam c++
    Hej na to som prišiel :) preto mi to zle mazalo v kopií, už som to doriešil vlastnými silami, aj keď niekto by mi mohol poradiť ako na optimálneho deštruktora. Ako je navýhodnejšie uvolnit pamät ktory si ten linearny zoznam alokuje? thx
    Řešení 1× (Xgamer (tazatel))
    8.3.2011 17:56 Sten
    Rozbalit Rozbalit vše Re: Linearny zoznam c++
    Třeba takto:
    cList::~cList()
    {
    	this->clear();
    }
    
    void cList::clear()
    {
    	struct destroyer
    	{
    		destroyer(cNode *first)
    			: current(first)
    		{}
    
    		~destroyer()
    		{
    			this->operator ()();
    		}
    
    		void operator ()()
    		{
    			while (this->current) {
    				cNode *n = this->current;
    				this->current = n->getNext();
    				delete n;
    			}
    		}
    
    		cNode *current;
    	};
    
    	destroyer d(this->first);
    	d();
    }
    
    Tohle správně zdestruuje celý seznam, i pokud destruktor některého cNode vyhodí výjimku.

    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.