Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 12-05-2008, 14:41   #1
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
[C#] using è da evitare?

Mi hanno appena sconsigliato di usare lo using perchè pare che crei casini e non sia del tutto equivalente al try/finally.
E in effetti sto riscontrando un problema sporadico in un applicativo decisamente sovraccaricato che potrebbe giustificare questa affermazione.

Ancora non ho avuto modo di discuterne approfonditamente con la persona che me lo ha detto.
Qualcun altro ne sa niente?
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 12-05-2008, 15:22   #2
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Quote:
Originariamente inviato da tomminno Guarda i messaggi
Mi hanno appena sconsigliato di usare lo using perchè pare che crei casini e non sia del tutto equivalente al try/finally.
E in effetti sto riscontrando un problema sporadico in un applicativo decisamente sovraccaricato che potrebbe giustificare questa affermazione.

Ancora non ho avuto modo di discuterne approfonditamente con la persona che me lo ha detto.
Qualcun altro ne sa niente?
Io all'inizio lo usavo spesso perchè leggendo in 'giro' mi era parso di capire che fosse un modo efficace per invocare la chiamata forzata al gc per la liberazione della memoria.

Non ho mai però visto grandi benefici rispetto a:

Dove necessario, far ereditare da Disposable la mia classe
Try/catch/Finally <- e qui chiamo esplicitamente il mio Close o Dispose.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 12-05-2008, 15:46   #3
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Quote:
Originariamente inviato da RaouL_BennetH Guarda i messaggi
Io all'inizio lo usavo spesso perchè leggendo in 'giro' mi era parso di capire che fosse un modo efficace per invocare la chiamata forzata al gc per la liberazione della memoria.

Non ho mai però visto grandi benefici rispetto a:

Dove necessario, far ereditare da Disposable la mia classe
Try/catch/Finally <- e qui chiamo esplicitamente il mio Close o Dispose.

Si', infatti dovrebbe essere equivalente. Solo un po' piu' leggibile.
In quanto a bachi non ne so nulla, ne si trova nulla su internet (1 minuti di ricerca pero', occorrerebbe approfondire)
Se mai ci fosse un baco non in una libreria, ma addirittura in una keyword penso sarebbero corsi a correggerlo immediatamente.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 12-05-2008, 16:55   #4
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da RaouL_BennetH Guarda i messaggi
Io all'inizio lo usavo spesso perchè leggendo in 'giro' mi era parso di capire che fosse un modo efficace per invocare la chiamata forzata al gc per la liberazione della memoria.

Non ho mai però visto grandi benefici rispetto a:

Dove necessario, far ereditare da Disposable la mia classe
Try/catch/Finally <- e qui chiamo esplicitamente il mio Close o Dispose.
Io lo uso praticamente ovunque ci sia una classe IDisposable, il codice riempito di try/finally secondo me diventa molto poco leggibile.
Penso ad esempio ad una connessione al db:
Codice:
SqlConnection conn = null;
try
{
conn = new SqlConnection(connectionString); SqlCommand cmd = null; try {
cmd = new SqlCommand(query, conn); ...
} finally {
cmd.Dispose();
}
} finally {
conn.Dispose();
}
Confrontato a:
Codice:
using (SqlConnection conn = new SqlConnection(connectionString))
{
using (SqlCommand cmd = new SqlCommand(query, conn)) {
...
}
}
E in ogni caso il Dispose può generare eccezione quindi ci vuole comunque un try esterno quindi è sempre un try/try/finally/catch.
L'inconveniente è che una eccezione dentro uno using non si propaga se il Dispose fallisce.

Ultima modifica di tomminno : 12-05-2008 alle 16:57.
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 12-05-2008, 21:50   #5
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Quote:
Originariamente inviato da tomminno Guarda i messaggi
E in ogni caso il Dispose può generare eccezione quindi ci vuole comunque un try esterno quindi è sempre un try/try/finally/catch.
L'inconveniente è che una eccezione dentro uno using non si propaga se il Dispose fallisce.
Ho provato, e il Dispose sembra propagare le eccezioni anche dentro una using
Ho capito male?

Codice:
class Program
{
    static void Main(string[] args)
    {
        using (ClasseFarlocca cf = new ClasseFarlocca())
        {
            Console.WriteLine("Step1");
        }
        Console.WriteLine("StepFinale");
        Console.ReadKey();
    }
}

public class ClasseFarlocca:IDisposable
{
    public ClasseFarlocca()
    {
    }

    #region IDisposable Members

    public void Dispose()
    {
        Console.WriteLine("StepDispose");
        throw new NotImplementedException();
    }

    #endregion
}
output:
Step1
StepDispose
Eccezione.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 13-05-2008, 08:43   #6
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da gugoXX Guarda i messaggi
Ho provato, e il Dispose sembra propagare le eccezioni anche dentro una using
Ho capito male?
Scusa mi sono espresso male, se c'è un eccezione dentro lo using e il Dispose fallisce non si vede l'eccezione interna allo using.
Se è fondamentale avere traccia delle possibili eccezioni interne bisonga afffidarsi a catene kilometriche di catch
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 13-05-2008, 08:51   #7
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Quote:
Originariamente inviato da tomminno Guarda i messaggi
Scusa mi sono espresso male, se c'è un eccezione dentro lo using e il Dispose fallisce non si vede l'eccezione interna allo using.
Se è fondamentale avere traccia delle possibili eccezioni interne bisonga afffidarsi a catene kilometriche di catch

Ah. Avevo capito male.
Ma cosa intendi per "Il dispose fallisce"?
E' strano, ma non ho avuto mai la sensazione che ci fosse qualcosa che non va.
Nel caso in cui ci fosse sia l'eccezione nel flusso della using e un'altra eccezione nella Dispose?
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.

Ultima modifica di gugoXX : 13-05-2008 alle 08:54.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 13-05-2008, 10:19   #8
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da gugoXX Guarda i messaggi
Ah. Avevo capito male.
Ma cosa intendi per "Il dispose fallisce"?
E' strano, ma non ho avuto mai la sensazione che ci fosse qualcosa che non va.
Nel caso in cui ci fosse sia l'eccezione nel flusso della using e un'altra eccezione nella Dispose?
Il Dipose delle classi che hanno a che fare con la rete può fallire sollevando una eccezione, magari non capita mai ma c'è l'eventualità.
Nel caso di doppia eccezione vedi solo quella del Dispose, perdi completamente le informazioni dell'eccezione interna.
Ad esempio la classe SqlConnection il cui Close solleva una SqlException.

Ultima modifica di tomminno : 13-05-2008 alle 10:21.
tomminno è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
Roscosmos ha posticipato (ancora) il lan...
Isar Aerospace si prepara al secondo lan...
Tory Bruno è entrato in Blue Orig...
Fujifilm lancia la cartuccia per archivi...
Dreame H15 Mix: la soluzione 7-in-1 per ...
AirPods Pro 3 in forte sconto su Amazon:...
36 offerte Amazon, molte appena partite:...
2 caricatori multipli eccezionali: da 28...
OLED e 360 Hz a un prezzo senza preceden...
Roborock Q10 S5+ a un prezzo molto conve...
Upgrade PC a prezzo ridotto: le migliori...
Sono i 6 smartphone migliori su Amazon: ...
Google Pixel 9a a 361€, mai così ...
Super sconti sugli spazzolini Oral-B, an...
Aspira a 6000Pa, lava bene, costa 139€: ...
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: 01:55.


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