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

    Jihokorejská kryptoměnová burza Bithumb přiznala vážné selhání interních systémů, které ji vystavilo riziku sabotáže a nezabránilo chybné transakci v hodnotě přes 40 miliard dolarů (814 miliard Kč). Druhá největší kryptoměnová burza v Koreji minulý týden při propagační akci omylem rozeslala zákazníkům zhruba 620 000 bitcoinů místo 620 000 wonů (8700 Kč). Incident vyvolal pokles ceny bitcoinu o 17 procent. Většinu

    … více »
    Ladislav Hagara | Komentářů: 4
    dnes 13:55 | Nová verze

    Google Chrome 145 byl prohlášen za stabilní. Nejnovější stabilní verze 145.0.7632.45 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Zpátky je podpora grafického formátu JPEG XL, viz Platform Status. Odstraněna byla před třemi lety. Nový dekodér JPEG XL jxl-rs je napsán v Rustu. Zobrazování JPEG XL lze vyzkoušet na testovací stránce. Povolit lze v nastavení chrome://flags (Enable JXL image format).

    Ladislav Hagara | Komentářů: 0
    včera 22:44 | Nová verze

    Byla vydána nová verze 1.26 programovacího jazyka Go (Wikipedie). Přehled novinek v poznámkách k vydání.

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

    CrossOver, komerční produkt založený na Wine, byl vydán ve verzi 26. Přehled novinek v ChangeLogu. CrossOver 26 vychází z Wine 11.0, D3DMetal 3.0, DXMT 0.72, Wine Mono 10.4.1 a vkd3d 1.18. Do 17. února lze koupit CrossOver+ se slevou 26 %.

    Ladislav Hagara | Komentářů: 13
    včera 14:22 | Komunita

    KiCad je nově k dispozici také jako balíček ve formátu AppImage. Stačí jej stáhnout, nastavit právo na spouštění a spustit [Mastodon, 𝕏].

    Ladislav Hagara | Komentářů: 0
    včera 13:22 | Zajímavý projekt

    Šenčenská firma Seeed Studio představila projekt levného robotického ramena reBot Arm B601, primárně coby pomůcky pro studenty a výzkumníky. Paže má 6 stupňů volnosti, dosah 650 mm a nosnost 1,5 kilogramu, podporované platformy mají být ROS1, ROS2, LeRobot, Pinocchio a Isaac Sim, krom toho bude k dispozici vlastní SDK napsané v Pythonu. Kompletní seznam součástek, videonávody a nejspíš i cena budou zveřejněny až koncem tohoto měsíce.

    … více »
    NUKE GAZA! 🎆 | Komentářů: 9
    včera 11:11 | Nová verze

    Byla vydána nová verze 36.0, tj. první stabilní verze nové řady 36, svobodného multimediálního centra MythTV (Wikipedie). Přehled novinek a vylepšení v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 1
    včera 04:44 | Nová verze

    Byl vydán LineageOS 23.2 (Mastodon). LineageOS (Wikipedie) je svobodný operační systém pro chytré telefony, tablety a set-top boxy založený na Androidu. Jedná se o nástupce CyanogenModu.

    Ladislav Hagara | Komentářů: 5
    včera 03:44 | IT novinky

    Od března budou mít uživatelé Discordu bez ověření věku pouze minimální práva vhodná pro teenagery.

    Ladislav Hagara | Komentářů: 23
    9.2. 23:43 | IT novinky

    Evropská komise (EK) předběžně shledala čínskou sociální síť pro sdílení krátkých videí TikTok návykovým designem v rozporu s unijním nařízením o digitálních službách (DSA). Komise, která je exekutivním orgánem Evropské unie a má rozsáhlé pravomoci, o tom informovala v tiskovém sdělení. TikTok v reakci uvedl, že EK o platformě vykreslila podle něj zcela nepravdivý obraz, a proto se bude bránit.… více »

    Ladislav Hagara | Komentářů: 24
    Které desktopové prostředí na Linuxu používáte?
     (19%)
     (6%)
     (0%)
     (11%)
     (26%)
     (3%)
     (5%)
     (2%)
     (12%)
     (28%)
    Celkem 843 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    Rozcestník

    Dotaz: Linearny zoznam c++

    Xgamer avatar 8.3.2011 15:23 Xgamer | skóre: 4
    Linearny zoznam c++
    Přečteno: 572×
    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.