Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
WF-1000X M6 è la sesta generazione di auricolare in-ear sviluppata da Sony, un prodotto che punta a coniugare facilità di utilizzo con una elevata qualità di riproduzione dei contenuti audio e una cura nella riduzione del rumore ambientale che sia da riferimento
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake ha presentato diverse novità per la sua piattaforma legate all'intelligenza artificiale. Quella forse più eclatante è una collaborazione con OpenAI, ma non mancano diverse nuove funzionalità che rendono la piattaforma più flessibile e in grado di rispondere meglio alle esigenze in continuo cambiamento delle aziende
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Con velocità teoriche fino a 11 Gbps, gestione tramite app intelligente e protezione avanzata dei dispositivi, Roamii BE Pro porta il Wi‑Fi 7 tri‑band nelle abitazioni più esigenti. Un sistema Wi-Fi Mesh proposto da MSI allo scopo di garantire agli utenti una rete fluida e continua capace di sostenere streaming 8K, gaming competitivo e le applicazioni moderne più esigenti in termini di banda
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 26-10-2012, 12:14   #1
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
[Ottimizzazione] Quale delle due soluzioni è migliore?

come da domanda, secondo voi quale soluzione è migliore?
Codice:
			String query="select ID_RISTAMPA from RISTAMPE where "+
			"CONTO_CORRENTE="+inputForm.getContoCorrente()+" and "+
			"DATA_ALLIBRAMENTO_FROM="+Util.formatView2DBDate(inputForm.getDataAllibramentoFrom())+" and "+
			"DATA_ALLIBRAMENTO_TO="+Util.formatView2DBDate(inputForm.getDataAllibramentoTo());
Codice:
String conto=inputForm.getContoCorrente();
String dataA=Util.formatView2DBDate(inputForm.getDataAllibramentoFrom());
String dataTo=Util.formatView2DBDate(inputForm.getDataAllibramentoTo());

			String query="select ID_RISTAMPA from RISTAMPE where "+
			"CONTO_CORRENTE="+conto+" and "+
			"DATA_ALLIBRAMENTO_FROM="+dataA+" and "+
			"DATA_ALLIBRAMENTO_TO="+dataTo;
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
Old 26-10-2012, 12:30   #2
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Migliore in che senso?

Spezzone 1:
Codice:
String query="select ID_RISTAMPA from RISTAMPE where "
+ "CONTO_CORRENTE="
+ inputForm.getContoCorrente() 
+ " and "
+ "DATA_ALLIBRAMENTO_FROM="
+ Util.formatView2DBDate(inputForm.getDataAllibramentoFrom())
+ " and "
+ "DATA_ALLIBRAMENTO_TO="
+ Util.formatView2DBDate(inputForm.getDataAllibramentoTo());
Analisi:
Quote:
1 string creation
8 string append (creation)
3 method call
Spezzone 2:
Codice:
String conto=inputForm.getContoCorrente();
String dataA=Util.formatView2DBDate(inputForm.getDataAllibramentoFrom());
String dataTo=Util.formatView2DBDate(inputForm.getDataAllibramentoTo());
String query="select ID_RISTAMPA from RISTAMPE where "
+ "CONTO_CORRENTE="
+ conto
+ " and "
+ "DATA_ALLIBRAMENTO_FROM="
+ dataA
+ " and "
+ "DATA_ALLIBRAMENTO_TO="
+ dataTo;
Analisi:
Quote:
4 string creation
3 method call
8 string append (creation)
Totale spezzone 1: 1+8 = 9 string creation
Totale spezzone 2: 4+8 = 12 string creation

Ottimizzazione: usa uno StringBuilder.

@EDIT:
Sempre ammesso che si parlasse di "ottimizzazione" circa l'uso delle stringhe e basta.
Altrimenti potresti usare i PreparedStatement invece di costruire la query concatenando stringhe, ci sono diversi vantaggi nel farlo (evitare sql injection, precompilare lo statement).
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)

Ultima modifica di banryu79 : 26-10-2012 alle 13:53.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 26-10-2012, 13:18   #3
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
La prima risposta che mi viene in mente è nessuna delle 2.
Le query composte come concatenamento di stringhe sono il male assoluto.

Poi passando alle performance della soluzione forse è il caso di usare StringBuilder (a occhio mi pare che il codice sia Java).
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 28-10-2012, 10:44   #4
starfred
Senior Member
 
Iscritto dal: Jul 2011
Messaggi: 381
Ma per "migliore" cosa intendi? Efficienza in tempo o in spazio?

Ricollegandomi a quello che ha detto banryu79, dal mio punto di vista, riferendomi alla complessità computazionale, i due esempi sono uguali. Dato che generalmente la creazione di stringhe ha complessità unitaria, quindi alla fine il tuo codice apparterrà alla classe di complessità della più grande ( "O grande" ) delle funzioni:

inputForm.getContoCorrente()
Util.formatView2DBDate(inputForm.getDataAllibramentoFrom())
Util.formatView2DBDate(inputForm.getDataAllibramentoTo())

Quindi se per esempio la getDataAllibramentoFrom ha complessità n^2 e le altre due hanno complessità n entrambi i codici alla fine avranno complessità O(n^2).
__________________
Concluso positivamente con: Kamzata, Ducati82, Arus, TheLastRemnant, ghost driver, alexbull1, DanieleRC5, XatiX

Ultima modifica di starfred : 28-10-2012 alle 10:47.
starfred è offline   Rispondi citando il messaggio o parte di esso
Old 31-10-2012, 10:54   #5
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
grazie a tutti e scusate se non ho risposto prima, ma ho avuto un pò da fare.

Sono passato ad uno stringbuilder, e mi interessava proprio la "computazione", ovvero se è peggio concatenare tante volte le stringhe oppure se è peggio creare tante variabili con spezzoni.

la disquisizione sulla complessità però mi ha fatto ragionare che praticamente, dato che stiamo parlando di pochi dati, è praticamente ininfluente.


credo che a livello spaziale lo stringbuilder ottimizzi il tutto, mentre a livello temporale credo siano equivalenti
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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...
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
GTA 6 gratis se nasce un figlio il giorn...
Quasi la metà degli smartphone at...
DDR5 a 16 dollari al gigabyte: Framework...
Meno di 3kg per 'diventare' bionici: l'u...
Al regalo di San Valentino ci pensa HUAW...
Intel multata in India: 30 milioni di do...
Beast of Reincarnation ha una data di us...
Provati Reno15 e Reno15 FS: analisi comp...
L'Europa sfida la Cina sul litio: in Fin...
Sono 32, di cui 6 nuove, le offerte Amaz...
Rinnovo dei coupon Amazon nascosti: ecco...
Corsair aggiorna la confezione delle RAM...
Ecco tutti i robot aspirapolvere in offe...
Tachyum: dal processore universale alle ...
L'eVTOL tedesco per missioni mediche e m...
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: 22:43.


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