Torna indietro   Hardware Upgrade Forum > Software > Programmazione

ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondono completezza e duttilità
ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondono completezza e duttilità
NUC 15 Pro e NUC 15 Pro+ sono i due nuovi mini-PC di casa ASUS pensati per uffici e piccole medie imprese. Compatti, potenti e pieni di porte per la massima flessibilità, le due proposte rispondono in pieno alle esigenze attuali e future grazie a una CPU con grafica integrata, accompagnata da una NPU per la gestione di alcuni compiti AI in locale.
Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint
Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint
Dal palco di Proofpoint Protect 2025 emerge la strategia per estendere la protezione dagli utenti agli agenti IA con il lancio di Satori Agents, nuove soluzioni di governance dei dati e partnership rafforzate che ridisegnano il panorama della cybersecurity
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Dopo alcuni anni di assenza dai cataloghi dei suoi televisori, Hisense riporta sul mercato una proposta OLED che punta tutto sul rapporto qualità prezzo. Hisense 55A85N è un televisore completo e versatile che riesce a convincere anche senza raggiungere le vette di televisori di altra fascia (e altro prezzo)
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 02-05-2013, 14: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 è online   Rispondi citando il messaggio o parte di esso
Old 03-05-2013, 20:22   #2
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2775
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, 22: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, 00: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 è online   Rispondi citando il messaggio o parte di esso
Old 06-05-2013, 10: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, 13: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 è online   Rispondi citando il messaggio o parte di esso
Old 06-05-2013, 15: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, 17: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 è online   Rispondi citando il messaggio o parte di esso
Old 07-05-2013, 08: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, 10: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 è online   Rispondi citando il messaggio o parte di esso
Old 07-05-2013, 10: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, 11: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 è online   Rispondi citando il messaggio o parte di esso
Old 07-05-2013, 13: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, 21: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 è online   Rispondi citando il messaggio o parte di esso
 Rispondi


ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondono completezza e duttilità ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondo...
Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint Cybersecurity: email, utenti e agenti IA, la nuo...
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti Hisense A85N: il ritorno all’OLED è convi...
Recensione Borderlands 4, tra divertimento e problemi tecnici Recensione Borderlands 4, tra divertimento e pro...
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale TCL NXTPAPER 60 Ultra: lo smartphone che trasfor...
Steelseries Arctis Nova Elite: le prime ...
30 anni di PlayStation da indossare: arr...
Amazon lancia gli Echo più potent...
Amazon rinnova la gamma Fire TV: ecco le...
Ring lancia le sue prime videocamere con...
Blink amplia la gamma di videocamere di ...
Jaguar Land Rover riprende (gradualmente...
HONOR inaugura il primo ALPHA Flagship S...
Yamaha: ecco il brevetto del 'finto moto...
'Console obsoleta e utenti ingannati': u...
Stop al ransomware su Google Drive, graz...
L'IA è la nuova interfaccia utent...
Battlefield 6: confermata la dimensione ...
Windows 11 porta il Wi-Fi 7 alle aziende...
Logitech MX Master 4 subito disponibile ...
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:58.


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