Torna indietro   Hardware Upgrade Forum > Software > Programmazione

I nuovi notebook Acer al debutto al Computex 2025
I nuovi notebook Acer al debutto al Computex 2025
Al Computex 2025 di Taipei Acer mostra una completa gamma di soluzioni notebook delle famiglie Swift, Aspire, Predator e Nitro pensati per gli utenti consumer oltre che per coloro che ricercano elevata potenza di elaborazione, per lavorare o per giocare. In base al modello troviamo piattaforme Intel, AMD oppure Qualcomm anche in abbinamento alle nuove GPU NVIDIA GeForce RTX 5000
Nutanix .NEXT: così l'azienda vuole aiutare i clienti a limitare la dipendenza da Broadcom
Nutanix .NEXT: così l'azienda vuole aiutare i clienti a limitare la dipendenza da Broadcom
All'evento globale di Nutanix l'azienda ha presentato una serie di novità mirate a ridurre la dipendenza dalle soluzioni di VMware/Broadcom. Arriva Cloud Native AOS, soluzione che non richiede di appoggiarsi ad hypervisor. Novità per Nutanix Enterprise AI. Potenziata la collaborazione con Pure Storage per uno storage dedicato ad altissime prestazioni
HUAWEI WATCH FIT 4 Pro: lo smartwatch che non ha rivali a questo prezzo!
HUAWEI WATCH FIT 4 Pro: lo smartwatch che non ha rivali a questo prezzo!
HUAWEI è capace di sorprendere ancora e quest’anno lo fa con questo nuovo smartwatch WATCH FIT 4 Pro che coniuga un design elegante e moderno con funzionalità di prim’ordine. Ultra-sottile con display AMOLED, funzionalità avanzate per sport e salute, e un'autonomia fino a 10 giorni.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 31-12-2008, 13:00   #1
robs05
Member
 
Iscritto dal: Jan 2007
Messaggi: 112
[C++]: Costruttori e disttrutori

Salve,

se ho questa situazione:

tre classi:

1)
Codice:
Classe classe_uno
{
    private:
         classe_due *array;

    public:
          classe_uno(){ array = new classe_due[10]; }
          ~classe_uno(){ delete []array; }

          void metodo1()
         { 
          ciclo for che inzializza array
             {
              classe_due *c2 = new classe_due(i)
              array[i] = *c2;
              array[i].metodo2(); //metodo classe 2
             }   
         }
};


2)
Codice:
Classe classe_due
{
    private:
          int a;
          vector<classe_tre> array2;

    public:

         classe_due(){};
         classe_due(int a){this->a = a;};
         ~classe_due(){};

         void metodo2()
         {
            inserisco alcuni oggetti classe_tre nel vector con push_back
         }
};


3)
Codice:
Classe classe_tre
{
    private:
        int x;
        int y;

    public:
        classe_tre(){};
        classe_tre(int x, int y){ ... };
        ~classe_tre(){};
};
quindi ho tre classi dove:
Nella prima ci sono oggetti della seconda e nella seconda ci sono oggetti della terza.

adesso se in un main
Codice:
int main()
{
      classe_uno *var = new classe_uno();
      
      var->metodo1();

     delete var;
}
Con l'istruzione delete[] var distruggo tutti gli oggetti creati?
mi è venuto il dubbio perchè leggendo ho trovato scritto che per deallocare oggetti allocati dinamicamente, ad una new deve corrispondere una delete.

In effetti in questo codice c'è una sola invocazione di delete della classe_uno che dealloca gli oggetti dell'array fomato da classe_due che a loro volta hanno oggetto della classe tre.
In effetti inserendo una frase di uscita per ogni distruttore come:
"distrutto oggetto della classe_x" dove x è uno, due o tre

quando il main arriva a delete var comunque vengono stampate tutte le cout presenti nei rispettivi costruttori.

e' giusta questa deallocazione anche se ad ogni new non corrisponde una delete?
robs05 è offline   Rispondi citando il messaggio o parte di esso
Old 31-12-2008, 14:31   #2
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
[quote=robs05;25648811]Salve,

se ho questa situazione:

tre classi:

1)
Codice:
Classe classe_uno
{
    private:
         classe_due *array;

    public:
          classe_uno(){ array = new classe_due[10]; }
          ~classe_uno(){ delete []array; }

          void metodo1()
         { 
          ciclo for che inzializza array
             {
              classe_due *c2 = new classe_due(i)
              array[i] = *c2;
              array[i].metodo2(); //metodo classe 2
             }   
         }
};
[quote=robs05;25648811]
Qui c'è un memory leak grosso come una casa.
Allochi con new e non deallochi la memoria allocata. L'istruzione

array[i] = *c2;

esegue una copia membro a membro della classe *c2 in array[i], che non equivale a mettere *c2 in array[i].
Usa una variabile automatica:

classe_due c2(i);
array[i] = c2;
array[i].metodo2(); //metodo classe 2

In alternativa puoi fare in modo che array sia un vettore di puntatori a classe_due. In tal caso assegni direttamente il puntatore, ma ovviamente li devi deallocare tutti e singolarmente nel distruttore di classe_uno, prima di deallocare array.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2009, 09:09   #3
robs05
Member
 
Iscritto dal: Jan 2007
Messaggi: 112
Ciao cionci,

ho modificato il mio codice grazie al tuo consiglio....

cmq.... riepilogando al situazione

Codice:
Classe classe_uno
{
    private:
         classe_due *array;

    public:
          classe_uno(){ array = new classe_due[10]; }
          ~classe_uno(){ delete []array; }

          void metodo1()
         { 
          ciclo for che inzializza array
             {
              classe_due c2(i):
              array[i] = c2;
              array[i].metodo2(); //metodo classe 2
             }   
         }
};

Codice:
Classe classe_due
{
    private:
          int a;
          vector<classe_tre> array2;

    public:

         classe_due(){};
         classe_due(int a){this->a = a;};
         ~classe_due(){};

         void metodo2()
         {
            classe_tre c3(x,y);
            array2.push_back(c3);
            //inserisco alcuni oggetti classe_tre nel vector con push_back
         }
};
e poi

Codice:
Classe classe_tre
{
    private:
        int x;
        int y;

    public:
        classe_tre(){};
        classe_tre(int x, int y){ ... };
        ~classe_tre(){};
};
non dovrei più avere memory leak? giusto così?
grazie
robs05 è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2009, 16:14   #4
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Così non ci dovrebbero essere memory leak.
cionci è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


I nuovi notebook Acer al debutto al Computex 2025 I nuovi notebook Acer al debutto al Computex 202...
Nutanix .NEXT: così l'azienda vuole aiutare i clienti a limitare la dipendenza da Broadcom Nutanix .NEXT: così l'azienda vuole aiuta...
HUAWEI WATCH FIT 4 Pro: lo smartwatch che non ha rivali a questo prezzo! HUAWEI WATCH FIT 4 Pro: lo smartwatch che non ha...
Test NIU RQi Sport, vi spieghiamo perché una moto così è perfetta Test NIU RQi Sport, vi spieghiamo perché ...
Start Campus: il datacenter raffreddato dal mare Start Campus: il datacenter raffreddato dal mare
Hideo Kojima morirà, ma la sua cr...
Senti chi parla! Davvero, ora, grazie al...
Tesla sempre peggio in Europa: un'aziend...
Le minacce di Trump funzionano: un altro...
Cosa succede in Amazon? Sconti anomali s...
Flop Call of Duty Warzone Mobile, Activi...
Roborock Qrevo Curv, sconto di 400€ per ...
OLED LG 2024 in sconto su Amazon: 55'' S...
Claude AI inventa una citazione in tribu...
HP Victus con GeForce RTX 4070 e Intel C...
Samsung Galaxy S25 Ultra scende ancora d...
Ancora più giù i prezzi di...
Usare le scorie nucleari per ottenere en...
Dreame L40S Pro Ultra vs Dreame X40 Ultr...
OpenAI Codex scrive codice e lo testa da...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 19:34.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v