Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 02-05-2013, 15:06   #1
rizzotti91
Senior Member
 
L'Avatar di rizzotti91
 
Iscritto dal: May 2005
Città: Messina
Messaggi: 15654
[C#] Prestazioni funzioni

Ciao, sto cercando di ottimizzare le prestazioni di un mio progetto ed ho un dubbio.
Ho una classe che svolge determinate operazioni ricorrenti nella mia applicazione, come per esempio caricare una DataTable in base ad una query:

Codice:
 public static DataTable CaricaDt(string query, DataTable dt)
        {
                try
                {
                    Connection.Apri();
                    MySqlDataAdapter da = new MySqlDataAdapter(query, Connection.cnMySql);
                    da.Fill(dt);
                    Connection.Chiudi();
                    return dt;
Praticamente io dalla classe in cui necessito di questa datatable "riempita", mando come parametri la query e la datatable, la funzione riempie questa data table e poi la restituisce.

Il fatto che io invii come parametro una dataTable, la quale viene riempita e poi restituita, non equivale al copiare la datatable quando la invio come parametro e poi afarla nuovamente ricopiare quando scrivo:
datagrid.DataSource=CaricaDt(query,table)?
Se non sbaglio, non passando il riferimento della dataTable, io vado ogni volta a farla ricreare in ram o sbaglio?
__________________
CASE: Antec 900 - ALI: Enermax Pro82+ 525W - MOBO: Asus Z97I-Plus - CPU: i7 4770k @ 4.4 Ghz 1.22v - DISSI: Noctua U-14S - RAM: 2x8GB Corsair Vengeance LP @ 1866 Mhz - VGA: GTX 1070 ARMOR 8G OC - Monitor: Acer XF270HU - SSD: Samsung 850 EVO 500 GB
MacBook Pro Retina 15" 2018 - i7 6 core, Radeon Pro 560X, 512 GB SSD
rizzotti91 è offline   Rispondi citando il messaggio o parte di esso
Old 03-05-2013, 21:22   #2
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2787
Sbagli perché dt, anche se non è passato "per riferimento", è un riferimento ad un oggetto datatable, in pratica è un indirizzo. Quindi quello che passi e quello che viene restituito è solo un indirizzo.

Vedi qui:
http://msdn.microsoft.com/it-it/libr...=vs.80%29.aspx
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 05-05-2013, 23:53   #3
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
HA ragione wingman.
E infatti nel tuo esempio e' anche inutile restituire la DataTable
E' sufficiente non restituire nulla (void), in quanto il chiamante sa gia' che verra' modificata la stessa datatable passata alla funzione.
__________________
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 06-05-2013, 01:42   #4
rizzotti91
Senior Member
 
L'Avatar di rizzotti91
 
Iscritto dal: May 2005
Città: Messina
Messaggi: 15654
Quote:
Originariamente inviato da gugoXX Guarda i messaggi
HA ragione wingman.
E infatti nel tuo esempio e' anche inutile restituire la DataTable
E' sufficiente non restituire nulla (void), in quanto il chiamante sa gia' che verra' modificata la stessa datatable passata alla funzione.
Siccome la uso così:

Codice:
dataGrid.DataSource = Database.CaricaDt(query, table);
Se tolgo il ritorno e metto void, mi dice "Impossibile convertire implicitamente il tipo void in object"..
__________________
CASE: Antec 900 - ALI: Enermax Pro82+ 525W - MOBO: Asus Z97I-Plus - CPU: i7 4770k @ 4.4 Ghz 1.22v - DISSI: Noctua U-14S - RAM: 2x8GB Corsair Vengeance LP @ 1866 Mhz - VGA: GTX 1070 ARMOR 8G OC - Monitor: Acer XF270HU - SSD: Samsung 850 EVO 500 GB
MacBook Pro Retina 15" 2018 - i7 6 core, Radeon Pro 560X, 512 GB SSD
rizzotti91 è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2013, 11:27   #5
[Kendall]
Senior Member
 
L'Avatar di [Kendall]
 
Iscritto dal: Jul 2005
Città: Vicenza
Messaggi: 1570
Quote:
Originariamente inviato da rizzotti91 Guarda i messaggi
Siccome la uso così:

Codice:
dataGrid.DataSource = Database.CaricaDt(query, table);
Se tolgo il ritorno e metto void, mi dice "Impossibile convertire implicitamente il tipo void in object"..

Codice:
Database.CaricaDt(query, dataGrid.DataSource);
[Kendall] è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2013, 14:28   #6
rizzotti91
Senior Member
 
L'Avatar di rizzotti91
 
Iscritto dal: May 2005
Città: Messina
Messaggi: 15654
Due domande:
- Per utilizzarla come dici tu, il metodo che variazioni dovrebbe subire? Perché così vuole come parametro una datatable;
- Ci sarebbero vantaggi prestazionali?
__________________
CASE: Antec 900 - ALI: Enermax Pro82+ 525W - MOBO: Asus Z97I-Plus - CPU: i7 4770k @ 4.4 Ghz 1.22v - DISSI: Noctua U-14S - RAM: 2x8GB Corsair Vengeance LP @ 1866 Mhz - VGA: GTX 1070 ARMOR 8G OC - Monitor: Acer XF270HU - SSD: Samsung 850 EVO 500 GB
MacBook Pro Retina 15" 2018 - i7 6 core, Radeon Pro 560X, 512 GB SSD
rizzotti91 è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2013, 16:17   #7
[Kendall]
Senior Member
 
L'Avatar di [Kendall]
 
Iscritto dal: Jul 2005
Città: Vicenza
Messaggi: 1570
Quote:
Originariamente inviato da rizzotti91 Guarda i messaggi
Due domande:
- Per utilizzarla come dici tu, il metodo che variazioni dovrebbe subire? Perché così vuole come parametro una datatable;
- Ci sarebbero vantaggi prestazionali?
Chiaramente era solo una traccia, e il metodo avrebbe bisogno di alcune modifiche.
Dal canto mio farei comunque in maniera differente e mi affiderei alle tecniche di binding. Ne hai mai avuto a che fare?
[Kendall] è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2013, 18:57   #8
rizzotti91
Senior Member
 
L'Avatar di rizzotti91
 
Iscritto dal: May 2005
Città: Messina
Messaggi: 15654
Quote:
Originariamente inviato da [Kendall] Guarda i messaggi
Chiaramente era solo una traccia, e il metodo avrebbe bisogno di alcune modifiche.
Dal canto mio farei comunque in maniera differente e mi affiderei alle tecniche di binding. Ne hai mai avuto a che fare?
Si, ma non le utilizzo in quanto programmo tutto manualmente ed effettuo anche tutte le query di inserimento e modifiche manualmente, la datagrid mi serve solo per visualizzare..
__________________
CASE: Antec 900 - ALI: Enermax Pro82+ 525W - MOBO: Asus Z97I-Plus - CPU: i7 4770k @ 4.4 Ghz 1.22v - DISSI: Noctua U-14S - RAM: 2x8GB Corsair Vengeance LP @ 1866 Mhz - VGA: GTX 1070 ARMOR 8G OC - Monitor: Acer XF270HU - SSD: Samsung 850 EVO 500 GB
MacBook Pro Retina 15" 2018 - i7 6 core, Radeon Pro 560X, 512 GB SSD
rizzotti91 è offline   Rispondi citando il messaggio o parte di esso
Old 07-05-2013, 09:58   #9
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Quote:
Originariamente inviato da rizzotti91 Guarda i messaggi
Due domande:
- Per utilizzarla come dici tu, il metodo che variazioni dovrebbe subire? Perché così vuole come parametro una datatable;
- Ci sarebbero vantaggi prestazionali?
Codice:
Database.CaricaDt(query, table);
dataGrid.DataSource = table;
Cambiando il parametro di ritorno della funzione in void, e null'altro.
__________________
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 07-05-2013, 11:25   #10
rizzotti91
Senior Member
 
L'Avatar di rizzotti91
 
Iscritto dal: May 2005
Città: Messina
Messaggi: 15654
Quote:
Originariamente inviato da gugoXX Guarda i messaggi
Codice:
Database.CaricaDt(query, table);
dataGrid.DataSource = table;
Cambiando il parametro di ritorno della funzione in void, e null'altro.
Differenze prestazionali?

Inviato dal mio GT-I9300 con Tapatalk 2
__________________
CASE: Antec 900 - ALI: Enermax Pro82+ 525W - MOBO: Asus Z97I-Plus - CPU: i7 4770k @ 4.4 Ghz 1.22v - DISSI: Noctua U-14S - RAM: 2x8GB Corsair Vengeance LP @ 1866 Mhz - VGA: GTX 1070 ARMOR 8G OC - Monitor: Acer XF270HU - SSD: Samsung 850 EVO 500 GB
MacBook Pro Retina 15" 2018 - i7 6 core, Radeon Pro 560X, 512 GB SSD
rizzotti91 è offline   Rispondi citando il messaggio o parte di esso
Old 07-05-2013, 11:54   #11
[Kendall]
Senior Member
 
L'Avatar di [Kendall]
 
Iscritto dal: Jul 2005
Città: Vicenza
Messaggi: 1570
Quote:
Originariamente inviato da rizzotti91 Guarda i messaggi
Differenze prestazionali?

Inviato dal mio GT-I9300 con Tapatalk 2
Nessuna, ma ci guadagni in pulizia e chiarezza del codice.

La funzione che hai scritto è lineare e non ha alcun punto critico in quanto essenzialmente è una serie di chiamate a librerie della .NET.
Le criticità pertanto possono esserci piuttosto nel codice scritto in tali librerie (cosa che sinceramente dubito essendo strarevisionate).
[Kendall] è offline   Rispondi citando il messaggio o parte di esso
Old 07-05-2013, 12:19   #12
rizzotti91
Senior Member
 
L'Avatar di rizzotti91
 
Iscritto dal: May 2005
Città: Messina
Messaggi: 15654
Ok grazie per il chiarimento.
Quindi ricapitolando, se ho capito bene, ogni qualvolta chiamo un metodo che lavora su una DataTable (o un oggetto .NET in generale? ), anche se tale metodo è in un'altra classe è come se stessi lavorando all'interno della classe in cui mi trovo a livello prestazionale? Non vado a perdere assolutamente nulla?
__________________
CASE: Antec 900 - ALI: Enermax Pro82+ 525W - MOBO: Asus Z97I-Plus - CPU: i7 4770k @ 4.4 Ghz 1.22v - DISSI: Noctua U-14S - RAM: 2x8GB Corsair Vengeance LP @ 1866 Mhz - VGA: GTX 1070 ARMOR 8G OC - Monitor: Acer XF270HU - SSD: Samsung 850 EVO 500 GB
MacBook Pro Retina 15" 2018 - i7 6 core, Radeon Pro 560X, 512 GB SSD
rizzotti91 è offline   Rispondi citando il messaggio o parte di esso
Old 07-05-2013, 14:45   #13
nico159
Senior Member
 
Iscritto dal: Aug 2003
Città: Barletta (BA)
Messaggi: 939
Quote:
Originariamente inviato da rizzotti91 Guarda i messaggi
Ok grazie per il chiarimento.
Quindi ricapitolando, se ho capito bene, ogni qualvolta chiamo un metodo che lavora su una DataTable (o un oggetto .NET in generale? ), anche se tale metodo è in un'altra classe è come se stessi lavorando all'interno della classe in cui mi trovo a livello prestazionale? Non vado a perdere assolutamente nulla?
Gli unici dati che vengono copiati se passati come argomento sono i dati primitivi (stranne String) e le struct

Per tutto il resto sì, vengono passati solo riferimenti
__________________
In a world without fences, who needs Gates?
Power by: Fedora 8 - Mac OS X 10.4.11
nico159 è offline   Rispondi citando il messaggio o parte di esso
Old 12-05-2013, 22:17   #14
rizzotti91
Senior Member
 
L'Avatar di rizzotti91
 
Iscritto dal: May 2005
Città: Messina
Messaggi: 15654
Altra piccola domanda: quando devo fare 3 query in base ad un valore inserito dall'utente per ricavare il valore di 3 campi di quel determinato record, inizialmente eseguivo le tre query singolarmente con ExecuteScalar ed avevo un valore alla volta, quindi un totale di 3 query.
Adesso stavo attuando il metodo di query unica, limitare il risultato ad una riga e mettere questa riga in una DataTable in modo che abbia tutti e tre i valori in un unico oggetto.
Di funzionare funziona ma mi chiedevo se sotto qualche punto di vista l'utilizzo di una DataTable per una sola riga potesse essere uno spreco e se fosse preferibile utilizzare altro o va bene così
__________________
CASE: Antec 900 - ALI: Enermax Pro82+ 525W - MOBO: Asus Z97I-Plus - CPU: i7 4770k @ 4.4 Ghz 1.22v - DISSI: Noctua U-14S - RAM: 2x8GB Corsair Vengeance LP @ 1866 Mhz - VGA: GTX 1070 ARMOR 8G OC - Monitor: Acer XF270HU - SSD: Samsung 850 EVO 500 GB
MacBook Pro Retina 15" 2018 - i7 6 core, Radeon Pro 560X, 512 GB SSD
rizzotti91 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Missione Artemis II diretta verso la Lun...
Toy Story 5 arriva al cinema: è l...
Intel cambia rotta su Linux? Nuove assun...
Samsung aggiorna Bixby con One UI 8.5: p...
L'Etiopia vieta le auto a combustione: a...
Pirateria audiovisiva: la Guardia di Fin...
Ubisoft conferma due nuovi Far Cry in sv...
Chi vincerà il Festival di Sanrem...
G42 e Cerebras portano in India un super...
Offerte aggiornate del weekend Amazon: 7...
4 MacBook Air in offerta e scende a 939€...
Chrome cambia il tuo modo di lavorare: o...
Minimo storico iPhone 17 su Amazon: 909€...
USA, incriminati tre ingegneri della Sil...
Xbox: Phil Spencer lascia dopo 38 anni, ...
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:48.


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