Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Polestar 3 Performance, test drive: comodità e potenza possono convivere
Polestar 3 Performance, test drive: comodità e potenza possono convivere
Abbiamo passato diversi giorni alla guida di Polestar 3, usata in tutti i contesti. Come auto di tutti i giorni è comodissima, ma se si libera tutta la potenza è stupefacente
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
In occasione del proprio Architecture Deep Dive 2025 Qualcomm ha mostrato in dettaglio l'architettura della propria prossima generazione di SoC destinati ai notebook Windows for ARM di prossima generazione. Snapdragon X2 Elite si candida, con sistemi in commercio nella prima metà del 2026, a portare nuove soluzioni nel mondo dei notebook sottili con grande autonomia
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
DJI Mini 5 Pro porta nella serie Mini il primo sensore CMOS da 1 pollice, unendo qualità d'immagine professionale alla portabilità estrema tipica di tutti i prodotti della famiglia. È un drone C0, quindi in un peso estremamente contenuto e che non richiede patentino, propone un gimbal rotabile a 225 gradi, rilevamento ostacoli anche notturno e autonomia fino a 36 minuti. Caratteristiche che rendono il nuovo drone un riferimento per creator e appassionati
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 11-01-2007, 20:44   #1
0rph3n
Senior Member
 
L'Avatar di 0rph3n
 
Iscritto dal: Apr 2005
Città: Resana - TV
Messaggi: 960
[.NET] IDisposable - oggetti managed e non

Ciao a tutti,
allora ho creato una classe che implementa l'interfaccia IDisposable.
Dalla pagina che ho linkato, si evince come il codice per sbarazzarsi degli oggetti managed debba essere rinchiuso in un if che ne impedisce l'esecuzione qualora l'oggetto venga triturato dal garbage collector.
Ora vengo al dunque:
dalle mie fetide conoscenze non mi risulta, ma ci sono risorse unmanaged all'interno del framework .net? se si quali sono?
gli oggetti che non implementano l'interfaccia IDisposable e che quindi non hanno il metodo Dispose, come vanno distrutti?

grassie
'iao
0rph3n è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2007, 10:52   #2
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Quote:
Originariamente inviato da 0rph3n
Ciao a tutti,
allora ho creato una classe che implementa l'interfaccia IDisposable.
Dalla pagina che ho linkato, si evince come il codice per sbarazzarsi degli oggetti managed debba essere rinchiuso in un if che ne impedisce l'esecuzione qualora l'oggetto venga triturato dal garbage collector.
Ora vengo al dunque:
dalle mie fetide conoscenze non mi risulta, ma ci sono risorse unmanaged all'interno del framework .net? se si quali sono?
gli oggetti che non implementano l'interfaccia IDisposable e che quindi non hanno il metodo Dispose, come vanno distrutti?

grassie
'iao

Ciao

Da quel poco che so di .NET, dato che lo sto studiando da poco, puoi garantirti una chiamata a Dispose() utilizzando qualcosa del genere:

Codice:
try

  {

     using(Oggetto myObj = new Object)
    {
            //codice vario
    } //in questo momento viene garantita la chiamata a Dispose()
      //ma ovviamente non si può predeterminare quando il GC distruggerà l'oggetto
  }

catch(Exception ex)
{
    //gestisci l'eccezione
}
C'è anche un modo per utilizzare i puntatori, che riguarda una sezione chiamata "unsafe code", ma purtroppo non ci sono ancora arrivato a livello di studio.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2007, 14:38   #3
0rph3n
Senior Member
 
L'Avatar di 0rph3n
 
Iscritto dal: Apr 2005
Città: Resana - TV
Messaggi: 960
Quote:
Originariamente inviato da RaouL_BennetH
Ciao

Da quel poco che so di .NET, dato che lo sto studiando da poco, puoi garantirti una chiamata a Dispose() utilizzando qualcosa del genere:

Codice:
cut
Ciao
grazie della risposta anche se io non voglio sapere come garantirmi una chiamata al metodo Dispose() da parte del garbage collector.
Anche perche il garbage collector non chiama quel metodo, ma esegue il distruttore dell'oggetto (che chiama il metodo privato Dispose(bool)).
Comunque riporto l'esempio che si può trovare su MSDN IDisposable, così che si abbia una base comune:
in verde i commenti di MSDN in rosso i miei (è più una traduzione che altro)
Codice:
        // A base class that implements IDisposable.
    // By implementing IDisposable, you are announcing that
    // instances of this type allocate scarce resources.
    public class MyResource: IDisposable
    {
        // Pointer to an external unmanaged resource.
        private IntPtr handle;
        // Other managed resource this class uses.
        private Component component = new Component();
        // Track whether Dispose has been called.
        private bool disposed = false;

        // The class constructor.
        public MyResource(IntPtr handle)
        {
            this.handle = handle;
        }

        // Implement IDisposable.
        // Do not make this method virtual.
        // A derived class should not be able to override this method.
        // Questo è il metodo pubblico da chiamare per distruggere
        // l'oggetto.
        // A sua volta chiama il metodo privato Dispose(bool)
        // passandogli true come parametro e indicandogli quindi
        // di sbarazzarsi sia delle risorse managed
        // sia di quelle non managed.
        // Infine chiama il metodo SupressFinalize del garbage collector
        // per togliere questo oggetto dalla coda
        // ed evitare una seconda e quindi inutile distruzione.
        public void Dispose()
        {
            Dispose(true);
            // This object will be cleaned up by the Dispose method.
            // Therefore, you should call GC.SupressFinalize to
            // take this object off the finalization queue
            // and prevent finalization code for this object
            // from executing a second time.
            GC.SuppressFinalize(this);
        }

        // Dispose(bool disposing) executes in two distinct scenarios.
        // If disposing equals true, the method has been called directly
        // or indirectly by a user's code. Managed and unmanaged resources
        // can be disposed.
        // If disposing equals false, the method has been called by the
        // runtime from inside the finalizer and you should not reference
        // other objects. Only unmanaged resources can be disposed.
        // Questo è il metodo che si occupa di smaltire
        // le risorse.
        // In questa implementazione può essere chiamato:
        //  sia dal metodo pubblico Dispose() (e quindi da codice)
        //  sia dal distruttore della classe (e quindi dal garbage collector).
        private void Dispose(bool disposing)
        {
            // Check to see if Dispose has already been called.
            if(!this.disposed)
            {
                // If disposing equals true, dispose all managed
                // and unmanaged resources.
                if(disposing)
                {
                    // Dispose managed resources.
                    component.Dispose();
                }

                // Call the appropriate methods to clean up
                // unmanaged resources here.
                // If disposing is false,
                // only the following code is executed.
                CloseHandle(handle);
                handle = IntPtr.Zero;

                // Note disposing has been done.
                disposed = true;

            }
        }

        // Use interop to call the method necessary
        // to clean up the unmanaged resource.
        [System.Runtime.InteropServices.DllImport("Kernel32")]
        private extern static Boolean CloseHandle(IntPtr handle);

        // Use C# destructor syntax for finalization code.
        // This destructor will run only if the Dispose method
        // does not get called.
        // It gives your base class the opportunity to finalize.
        // Do not provide destructors in types derived from this class.
        // Questo è il distruttore della classe.
        // Viene invocato dal garbage collector.
        // A sua volta chiama il metodo privato Dispose(bool)
        // passandogli false come parametro e indicandogli quindi
        // di sbarazzarsi solo delle risorse non managed,
        // in quanto quelle managed verranno distrutte dal garbage collector.
        ~MyResource()
        {
            // Do not re-create Dispose clean-up code here.
            // Calling Dispose(false) is optimal in terms of
            // readability and maintainability.
            Dispose(false);
        }
    }
Quote:
Originariamente inviato da RaouL_BennetH
C'è anche un modo per utilizzare i puntatori, che riguarda una sezione chiamata "unsafe code", ma purtroppo non ci sono ancora arrivato a livello di studio.
quella sezione dovrebbe riferirsi alle risorse non managed, il cui caso è trattato nell'esempio che ho postato sopra!

comunque ripeto le mie domande iniziali:
  • esistono oggetti non managed all'interno del framework .net?
  • se si, quali sono?
  • come si distruggono gli oggetti che non implementano l'interfaccia IDisposable e che quindi non hanno il metodo Dispose()?
0rph3n è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2007, 18:07   #4
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Quote:
Originariamente inviato da 0rph3n
Ciao
grazie della risposta anche se io non voglio sapere come garantirmi una chiamata al metodo Dispose() da parte del garbage collector.
Anche perche il garbage collector non chiama quel metodo, ma esegue il distruttore dell'oggetto (che chiama il metodo privato Dispose(bool)).
Comunque riporto l'esempio che si può trovare su MSDN IDisposable, così che si abbia una base comune:
in verde i commenti di MSDN in rosso i miei (è più una traduzione che altro)
Codice:
        // A base class that implements IDisposable.
    // By implementing IDisposable, you are announcing that
    // instances of this type allocate scarce resources.
    public class MyResource: IDisposable
    {
        // Pointer to an external unmanaged resource.
        private IntPtr handle;
        // Other managed resource this class uses.
        private Component component = new Component();
        // Track whether Dispose has been called.
        private bool disposed = false;

        // The class constructor.
        public MyResource(IntPtr handle)
        {
            this.handle = handle;
        }

        // Implement IDisposable.
        // Do not make this method virtual.
        // A derived class should not be able to override this method.
        // Questo è il metodo pubblico da chiamare per distruggere
        // l'oggetto.
        // A sua volta chiama il metodo privato Dispose(bool)
        // passandogli true come parametro e indicandogli quindi
        // di sbarazzarsi sia delle risorse managed
        // sia di quelle non managed.
        // Infine chiama il metodo SupressFinalize del garbage collector
        // per togliere questo oggetto dalla coda
        // ed evitare una seconda e quindi inutile distruzione.
        public void Dispose()
        {
            Dispose(true);
            // This object will be cleaned up by the Dispose method.
            // Therefore, you should call GC.SupressFinalize to
            // take this object off the finalization queue
            // and prevent finalization code for this object
            // from executing a second time.
            GC.SuppressFinalize(this);
        }

        // Dispose(bool disposing) executes in two distinct scenarios.
        // If disposing equals true, the method has been called directly
        // or indirectly by a user's code. Managed and unmanaged resources
        // can be disposed.
        // If disposing equals false, the method has been called by the
        // runtime from inside the finalizer and you should not reference
        // other objects. Only unmanaged resources can be disposed.
        // Questo è il metodo che si occupa di smaltire
        // le risorse.
        // In questa implementazione può essere chiamato:
        //  sia dal metodo pubblico Dispose() (e quindi da codice)
        //  sia dal distruttore della classe (e quindi dal garbage collector).
        private void Dispose(bool disposing)
        {
            // Check to see if Dispose has already been called.
            if(!this.disposed)
            {
                // If disposing equals true, dispose all managed
                // and unmanaged resources.
                if(disposing)
                {
                    // Dispose managed resources.
                    component.Dispose();
                }

                // Call the appropriate methods to clean up
                // unmanaged resources here.
                // If disposing is false,
                // only the following code is executed.
                CloseHandle(handle);
                handle = IntPtr.Zero;

                // Note disposing has been done.
                disposed = true;

            }
        }

        // Use interop to call the method necessary
        // to clean up the unmanaged resource.
        [System.Runtime.InteropServices.DllImport("Kernel32")]
        private extern static Boolean CloseHandle(IntPtr handle);

        // Use C# destructor syntax for finalization code.
        // This destructor will run only if the Dispose method
        // does not get called.
        // It gives your base class the opportunity to finalize.
        // Do not provide destructors in types derived from this class.
        // Questo è il distruttore della classe.
        // Viene invocato dal garbage collector.
        // A sua volta chiama il metodo privato Dispose(bool)
        // passandogli false come parametro e indicandogli quindi
        // di sbarazzarsi solo delle risorse non managed,
        // in quanto quelle managed verranno distrutte dal garbage collector.
        ~MyResource()
        {
            // Do not re-create Dispose clean-up code here.
            // Calling Dispose(false) is optimal in terms of
            // readability and maintainability.
            Dispose(false);
        }
    }
quella sezione dovrebbe riferirsi alle risorse non managed, il cui caso è trattato nell'esempio che ho postato sopra!

comunque ripeto le mie domande iniziali:
  • esistono oggetti non managed all'interno del framework .net?
  • se si, quali sono?
  • come si distruggono gli oggetti che non implementano l'interfaccia IDisposable e che quindi non hanno il metodo Dispose()?

Eheh, scusami, davvero non avevo colto il senso delle tue domande, anzi, ti ringrazio io per avermi insegnato qualcosa in più
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2007, 19:13   #5
0rph3n
Senior Member
 
L'Avatar di 0rph3n
 
Iscritto dal: Apr 2005
Città: Resana - TV
Messaggi: 960
Quote:
Originariamente inviato da RaouL_BennetH
Eheh, scusami, davvero non avevo colto il senso delle tue domande, anzi, ti ringrazio io per avermi insegnato qualcosa in più
figurati , quando si può è bello.
adesso spero che arrivi qualcuno che mi sappia illuminare
intanto io continuerò a cercare un po' in giro per vedere se trovo qualcosa!

'iao
0rph3n è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Polestar 3 Performance, test drive: comodità e potenza possono convivere Polestar 3 Performance, test drive: comodit&agra...
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026 Qualcomm Snapdragon X2 Elite: l'architettura del...
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice Recensione DJI Mini 5 Pro: il drone C0 ultra-leg...
ASUS Expertbook PM3: il notebook robusto per le aziende ASUS Expertbook PM3: il notebook robusto per le ...
Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo Test ride con Gowow Ori: elettrico e off-road va...
Grazie a VLT è stata misurata dir...
Blue Origin annuncia un aerofreno ripieg...
Blue Origin annuncia una nuova versione ...
LG UltraFine evo 6K: il primo monitor al...
DJI cambia direzione: investe in Elegoo ...
Black Friday Narwal 2025: risparmi da ca...
Phishing evoluto contro Apple ID: caso f...
Prestazioni in discesa nei giochi? NVIDI...
Addio ai banner dei cookie? L'UE spinge ...
Le offerte Black Friday per gli smartpho...
Il controllo qualità degli iPhone...
Qualcomm Snapdragon X Elite vola con il ...
A2RL Season 2: storia, innovazione e sor...
Core Ultra Series 3: Intel conferma l'ev...
Black Friday Amazon: la GeForce RTX 5070...
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: 03:01.


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