Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Al .NEXT 2026 di Chicago, Nutanix ha mostrato quanto sia cambiata: una piattaforma software che gestisce VM, container e carichi di lavoro IA ovunque, dall’on-premise al cloud pubblico. Con un’esecuzione rapidissima sulle partnership e sulla migrazione da VMware
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta
Xiaomi Pad 8 Pro adotta il potente Snapdragon 8 Elite all'interno di un corpo con spessore di soli 5,75 mm e pannello LCD a 144Hz flicker-free, per un tablet che può essere utilizzato con accessori dedicati di altissima qualità. Fra le caratteristiche esclusive, soprattutto per chi intende usarlo con la tastiera ufficiale, c'è la modalità Workstation di HyperOS 3, che trasforma Android in un sistema operativo con interfaccia a finestre
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


Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abb...
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz ASUS ROG Swift OLED PG34WCDN recensione: il prim...
Intel, focus su GPU workstation e datace...
Addio definitivo a iOS 26.4, Apple blocc...
EPYC di nuova generazione: AMD supporter...
AMD, Arm e Qualcomm scommettono su Wayve...
Intel potrebbe estendere la vita del soc...
Windows, gli aggiornamenti di aprile for...
Addio cavi perimetrali: il robot tosaerb...
Google Pixel 10 oggi proposto a soli 549...
I robot di Boston Dynamics possono inter...
Tech, gadget e accessori a meno di 5€ su...
Ford riorganizza la divisione elettrica:...
Elon Musk trasforma xAI in fornitore di ...
Pirateria musicale: batosta record per A...
iRobot riparte: nuova era con Picea, Roo...
Bitcoin: Killing Satoshi, film sul miste...
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: 13:18.


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