Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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 colori, e davvero tascabile
BOOX Palma 2 Pro è l'ultima evoluzione della gamma Palma. Ma di cosa si tratta? In breve è un dispositivo e-ink da 6,13 pollici che sfida le convenzioni con un display Kaleido 3 a colori, supporto per stilo InkSense Plus, connettività 5G solo dati e alimentato dal sistema operativo Android 15. Con queste caratteristica si configura come qualcosa in più di un semplice e-reader
FRITZ!Repeater 1700 estende la rete super-veloce Wi-Fi 7
FRITZ!Repeater 1700 estende la rete super-veloce Wi-Fi 7
FRITZ!Repeater 1700 porta il Wi-Fi 7 dual-band nelle case connesse. Mette a disposizione fino a 2.880 Mbit/s su 5 GHz e 688 Mbit/s su 2,4 GHz, integrazione Mesh immediata via WPS con FRITZ!Box e funzioni smart come MLO per bassa latenza. Compatto, plug-and-play e pronto per il futuro, è la soluzione ideale per chi vuole coprire ogni angolo senza cavi o complicazioni
Fondazione Chips-IT, l'Italia alla riscossa nei chip. Il piano e la partnership EssilorLuxottica
Fondazione Chips-IT, l'Italia alla riscossa nei chip. Il piano e la partnership EssilorLuxottica
La Fondazione Chips-IT ha presentato a Pavia il piano strategico 2026-2028 per rafforzare l'ecosistema italiano dei semiconduttori. Con un focus su ricerca, design, talenti e infrastrutture, la Fondazione punta a consolidare il ruolo dell'Italia nel Chips Act europeo, sostenendo innovazione, collaborazione industriale e sovranità tecnologica.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 17-03-2005, 19:20   #1
gik25
Senior Member
 
L'Avatar di gik25
 
Iscritto dal: Feb 2001
Messaggi: 1047
Ottimizzazione massima: codice eseguito 27000 volte

si tratta di eseguire 5 sostituzione su una stringa.

Es.

stringa = stringa.sostituisci("var1", var1);
stringa = stringa.sostituisci("var2", var2);
stringa = stringa.sostituisci("var3", var3);
stringa = stringa.sostituisci("var4", var4);
stringa = stringa.sostituisci("var5", var5);

Non posso effettuare l'operazione per riferimento perchè il metodo sostituisci di C# (il linguaggio che uso) non lo supporta.
gik25 è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2005, 22:20   #2
tglman
Senior Member
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 414
cherca di usare i puntatori invece che l'oggetto string (il c# li dorebbe supportare)
cioe ti vai la variabile cher * stringa che punta direttamente all'area di memoria che contenga la string a meno che tu dopo non devi utilizare una funzione dell'oggetto string
Ciao..
tglman è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2005, 22:23   #3
Futuregames
Senior Member
 
Iscritto dal: Mar 2005
Messaggi: 349
cmq 27000 volte nn sono un po troppe?
Futuregames è offline   Rispondi citando il messaggio o parte di esso
Old 18-03-2005, 08:13   #4
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da Futuregames
cmq 27000 volte nn sono un po troppe?
Dipende da quello che devi fare

Lo devi eseguire su un P4 con Hyper Threading ? In tal caso potresti creare due thread separati...la velocità ti dovrebbe aumentare di circa il 50-60%...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 18-03-2005, 10:58   #5
gik25
Senior Member
 
L'Avatar di gik25
 
Iscritto dal: Feb 2001
Messaggi: 1047
Quote:
Originariamente inviato da cionci
Dipende da quello che devi fare

Lo devi eseguire su un P4 con Hyper Threading ? In tal caso potresti creare due thread separati...la velocità ti dovrebbe aumentare di circa il 50-60%...
No, purtroppo è su un athlon
gik25 è offline   Rispondi citando il messaggio o parte di esso
Old 18-03-2005, 17:33   #6
sirus
Senior Member
 
Iscritto dal: Mar 2004
Messaggi: 16053
Quote:
Originariamente inviato da cionci
Dipende da quello che devi fare

Lo devi eseguire su un P4 con Hyper Threading ? In tal caso potresti creare due thread separati...la velocità ti dovrebbe aumentare di circa il 50-60%...
solo per curiosità...
in C++ si potrebbe creare due th separati???
come???
sirus è offline   Rispondi citando il messaggio o parte di esso
Old 18-03-2005, 20:07   #7
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Certo... Su Windows si possono usare le API, su Linux i pthread...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 18-03-2005, 20:08   #8
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da gik25
No, purtroppo è su un athlon
Prova ad implementare una funzione che lavora direttamente sulla stringa...magari con un solo ciclo potresti controllare tutte e 5 le stringhe...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 18-03-2005, 20:15   #9
gik25
Senior Member
 
L'Avatar di gik25
 
Iscritto dal: Feb 2001
Messaggi: 1047
Risolto usando la classe StringBuilder
gik25 è offline   Rispondi citando il messaggio o parte di esso
Old 18-03-2005, 20:18   #10
/\/\@®¢Ø
Bannato
 
L'Avatar di /\/\@®¢Ø
 
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
Re: Ottimizzazione massima: codice eseguito 27000 volte

Quote:
Originariamente inviato da gik25
si tratta di eseguire 5 sostituzione su una stringa.

Es.

stringa = stringa.sostituisci("var1", var1);
stringa = stringa.sostituisci("var2", var2);
stringa = stringa.sostituisci("var3", var3);
stringa = stringa.sostituisci("var4", var4);
stringa = stringa.sostituisci("var5", var5);

Non posso effettuare l'operazione per riferimento perchè il metodo sostituisci di C# (il linguaggio che uso) non lo supporta.
Non te lo lascia fare perche' probabilmente prevede la possibilita' di sostituire stringhe di una dimensione con stringhe di altra. Se proprio hai bisogno di maggiore velocita', e non devi cambiare la dimensione della stringa, butta tutto in un vector e ti scrivi tu la funzione di sostituzione.
/\/\@®¢Ø è offline   Rispondi citando il messaggio o parte di esso
Old 18-03-2005, 20:29   #11
gik25
Senior Member
 
L'Avatar di gik25
 
Iscritto dal: Feb 2001
Messaggi: 1047
Re: Re: Ottimizzazione massima: codice eseguito 27000 volte

Quote:
Originariamente inviato da /\/\@®¢Ø
Non te lo lascia fare perche' probabilmente prevede la possibilita' di sostituire stringhe di una dimensione con stringhe di altra. Se proprio hai bisogno di maggiore velocita', e non devi cambiare la dimensione della stringa, butta tutto in un vector e ti scrivi tu la funzione di sostituzione.
Ho risolto con StringBuilder

Si, ma è grazie a queste cazzate e alla continua segnalazione di "Impossibile convertire String in StringBuilder senza che il programmatore si rompa le palle a esplicitarlo" che i programmi fanno tutti pena e superano budget e tempi.
gik25 è offline   Rispondi citando il messaggio o parte di esso
Old 19-03-2005, 14:03   #12
/\/\@®¢Ø
Bannato
 
L'Avatar di /\/\@®¢Ø
 
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
Re: Re: Re: Ottimizzazione massima: codice eseguito 27000 volte

Quote:
Originariamente inviato da gik25
Ho risolto con StringBuilder

Si, ma è grazie a queste cazzate e alla continua segnalazione di "Impossibile convertire String in StringBuilder senza che il programmatore si rompa le palle a esplicitarlo" che i programmi fanno tutti pena e superano budget e tempi.
Pensandoci bene, mi sembra molto ragionevole invece. Se le stringhe sono immutabili (come mi sembra sia nel C#), ne segue immediatamente che non esiste alcuna funzione/metodo in grado di modificarle, ergo bisogna orientarsi subito su di un'altra classe.

Di solito disguidi come questi dipendono solo dal fatto che si ha esperienza con un linguaggio che si comporta diversamente, tipicamente C o C++.
/\/\@®¢Ø è offline   Rispondi citando il messaggio o parte di esso
Old 19-03-2005, 14:55   #13
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Re: Re: Re: Ottimizzazione massima: codice eseguito 27000 volte

Quote:
Originariamente inviato da gik25
Ho risolto con StringBuilder

Si, ma è grazie a queste cazzate e alla continua segnalazione di "Impossibile convertire String in StringBuilder senza che il programmatore si rompa le palle a esplicitarlo" che i programmi fanno tutti pena e superano budget e tempi.
potresti spiegarmi per piacere cosa intendi con questo?

Thx.

RaouL.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 19-03-2005, 23:17   #14
/\/\@®¢Ø
Bannato
 
L'Avatar di /\/\@®¢Ø
 
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
Re: Re: Re: Re: Ottimizzazione massima: codice eseguito 27000 volte

Quote:
Originariamente inviato da RaouL_BennetH
potresti spiegarmi per piacere cosa intendi con questo?

Thx.

RaouL.
Probabilmente che e' in ritardo col progetto e che a causa del contrattempo in questione si e' guadagnato nuovamente qualche rimbrotto da chi aspetta risultati


Se e' cosi' non preoccuparti gik, sei in buona compagnia
/\/\@®¢Ø è offline   Rispondi citando il messaggio o parte di esso
Old 19-03-2005, 23:31   #15
gik25
Senior Member
 
L'Avatar di gik25
 
Iscritto dal: Feb 2001
Messaggi: 1047
Re: Re: Re: Re: Re: Ottimizzazione massima: codice eseguito 27000 volte

Quote:
Originariamente inviato da /\/\@®¢Ø
Probabilmente che e' in ritardo col progetto e che a causa del contrattempo in questione si e' guadagnato nuovamente qualche rimbrotto da chi aspetta risultati


Se e' cosi' non preoccuparti gik, sei in buona compagnia


Ancora sono solo uno studente, ma già adesso sono stanco di vedere un proggetto che richiede un'ora di lavoro durare 10 ore per via di cast esplici che sono richiesti anche per convertire da char[] a string.

è una stupida esagerazione. Se una colonna di database contiene solo interi a che pro devo convertirla in int? Tanto più che la conversione non gestisce le eventuali eccezzioni (in caso di valore null).

Peggio ancora Java che richiede di gestire tutte le eccezioni, quando si sa bene come verranno gestite dopo che uno si romperà le balle(try e catch globale nel main)


Ma non basterebbe creare un megadatabase di snippet di codice e consultarli dinamicamente inserendoli nel codice in automatico?

Bah... in dieci anni i progressi sono stati veramente minimi.
gik25 è offline   Rispondi citando il messaggio o parte di esso
Old 19-03-2005, 23:37   #16
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
scusate, ma non è un po' strano parlare di ottimizzazione con un linguaggio come il C#?
lo dico sempre io: "the right tool for the right job"
negli ultimi tempi l'avrò ripetuto centiania di volte...
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 20-03-2005, 01:48   #17
gik25
Senior Member
 
L'Avatar di gik25
 
Iscritto dal: Feb 2001
Messaggi: 1047
Con la nuova versione del framework e qualche ottimizzazione sono passato da 12 minuti a 12 secondi...

Fare una cosa così in assembler avrebbe richiesto 12..... mesi di programmazione e altri 12 per capire dove sta l'errore.

No, io guardo al futuro non al passato. Vorrei linguaggi che supportino anche reti neurali e similprolog con editor evolutissimi che non richiedano la scrittura di codice, ma la selezione di snippet e il collegamento di unit per poi passare il tutto a compilatori decenti.

Per darti un'idea qualcosa di mille volte superiore a Web Ratio potrebbe andare bene.
gik25 è offline   Rispondi citando il messaggio o parte di esso
Old 20-03-2005, 10:55   #18
fek
Senior Member
 
L'Avatar di fek
 
Iscritto dal: Oct 2002
Città: San Jose, California
Messaggi: 11794
Quote:
Originariamente inviato da 71104
scusate, ma non è un po' strano parlare di ottimizzazione con un linguaggio come il C#?
Non e' mai strano parlare di ottimizzazione in nessun linguaggio.
E' strano parlare di ottimizzazione invece se non si e' sicuri che un determinato pezzo di codice e' un collo di bottiglia. E per esserne sicuri servono i dati di un profiler.
fek è offline   Rispondi citando il messaggio o parte di esso
Old 20-03-2005, 11:20   #19
Banus
Senior Member
 
L'Avatar di Banus
 
Iscritto dal: Nov 2002
Città: Singularity
Messaggi: 894
Re: Re: Re: Re: Re: Re: Ottimizzazione massima: codice eseguito 27000 volte

Quote:
Originariamente inviato da gik25
Ma non basterebbe creare un megadatabase di snippet di codice e consultarli dinamicamente inserendoli nel codice in automatico?
Il problema poi sarebbe... come scegliere lo snippet giusto in un milione di record?

Però sarebbe utile un supporto dei design pattern negli ambienti di sviluppo. Qualcosa c'è (XDoclet con generazione di codice automatica, ad esempio) ma c'è il problema di prendere confidenza con un ambiente e la sua logica...
__________________
echo 'main(k){float r,i,j,x,y=-15;while(puts(""),y++<16)for(x=-39;x++<40;putchar(" .:-;!/>"[k&7])) for(k=0,r=x/20,i=y/8;j=r*r-i*i+.1, i=2*r*i+.6,j*j+i*i<11&&k++<111;r=j);}'&>jul.c;gcc -o jul jul.c;./jul |Only Connect| "To understand is to perceive patterns" Isaiah Berlin "People often speak of their faith, but act according to their instincts." Nietzsche - Bayesian Empirimancer - wizardry
Banus è offline   Rispondi citando il messaggio o parte di esso
Old 20-03-2005, 11:45   #20
gik25
Senior Member
 
L'Avatar di gik25
 
Iscritto dal: Feb 2001
Messaggi: 1047
Quote:
Originariamente inviato da fek
Non e' mai strano parlare di ottimizzazione in nessun linguaggio.
E' strano parlare di ottimizzazione invece se non si e' sicuri che un determinato pezzo di codice e' un collo di bottiglia. E per esserne sicuri servono i dati di un profiler.
L'ho usato. Ma anche quelli (come tutto il resto del software) sono fatti veramente male.

Sarò un perfezionista ma vedo tutto migliorabile e di tanto.

I 5 o 6 profiler che ho provato sono giocattolini per bambini. Ogni volta restituiscono un valore diverso. NOn forniscono nemmeno il tempo*n° esecuzione linea.

Ho provato ANTS, PROFILER, quello della microsoft e altri che non sono nemmeno riuscito ad avviare
gik25 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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 ...
FRITZ!Repeater 1700 estende la rete super-veloce Wi-Fi 7 FRITZ!Repeater 1700 estende la rete super-veloce...
Fondazione Chips-IT, l'Italia alla riscossa nei chip. Il piano e la partnership EssilorLuxottica Fondazione Chips-IT, l'Italia alla riscossa nei ...
Nutanix: innovazione, semplicità e IA al centro della strategia hybrid multicloud Nutanix: innovazione, semplicità e IA al ...
Lenovo LOQ 15i Gen 10 (15IRX10) alla prova: il notebook gaming 'budget' che non ti aspetti Lenovo LOQ 15i Gen 10 (15IRX10) alla prova: il n...
Hyundai e LifeGate presentano una soluzi...
IA: un italiano su quattro la vorrebbe a...
MSI MEG X870E Godlike X: solo 1.000 unit...
I Robotaxi di Tesla registrano un tasso ...
GOG Patrons è ufficiale: la commu...
smart #2: le foto spia rivelano il ritor...
Ford sceglie l'IA al posto degli EV: la ...
Urbanista Palermo a meno di 40 euro: ANC...
Gruppo Marino e WINDTRE BUSINESS: sicure...
Il nuovo CEO di Mozilla e la strategia p...
Google punta al salto di qualità ...
Windows 11 attiva in automatico il servi...
Arctic MX-7: la nuova generazione di pas...
Di Caprio, 'Una battaglia dopo l'altra' ...
Intel cambia pelle: nuovi manager e lega...
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: 04:06.


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