Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Samsung Galaxy S25 Edge: il top di gamma ultrasottile e leggerissimo. La recensione
Samsung Galaxy S25 Edge: il top di gamma ultrasottile e leggerissimo. La recensione
Abbiamo provato il nuovo Galaxy S25 Edge, uno smartphone unico per il suo spessore di soli 5,8 mm e un peso super piuma. Parliamo di un device che ha pro e contro, ma sicuramente si differenzia dalla massa per la sua portabilità, ma non senza qualche compromesso. Ecco la nostra prova completa.
HP Elitebook Ultra G1i 14 è il notebook compatto, potente e robusto
HP Elitebook Ultra G1i 14 è il notebook compatto, potente e robusto
Pensato per il professionista sempre in movimento, HP Elitebook Ultra G1i 14 abbina una piattaforma Intel Core Ultra 7 ad una costruzione robusta, riuscendo a mantenere un peso contenuto e una facile trasportabilità. Ottime prestazioni per gli ambiti di produttività personale con un'autonomia lontano dalla presa di corrente che permette di lavorare per tutta la giornata
Microsoft Surface Pro 12 è il 2 in 1 più compatto e silenzioso
Microsoft Surface Pro 12 è il 2 in 1 più compatto e silenzioso
Basato su piattaforma Qualcomm Snapdragon X Plus a 8 core, il nuovo Microsoft Surface Pro 12 è un notebook 2 in 1 molto compatto che punta sulla facilità di trasporto, sulla flessibilità d'uso nelle differenti configurazioni, sul funzionamento senza ventola e sull'ampia autonomia lontano dalla presa di corrente
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 08-03-2013, 14:02   #1
biowep
Member
 
L'Avatar di biowep
 
Iscritto dal: Nov 2010
Messaggi: 211
Codice nel try meno performante?

Ciao, esiste qualche differenza nel tempi di esecuzione del codice in un una struttura try? Dovrebbero esserci per forza, perché altrimenti non avrebbe senso inserire solo alcune parti di codice ma tutto il programma e dovrebbe essere previsto di default, senza nemmeno essere esplicitato.
biowep è offline   Rispondi citando il messaggio o parte di esso
Old 08-03-2013, 14:23   #2
The_ouroboros
Senior Member
 
L'Avatar di The_ouroboros
 
Iscritto dal: May 2007
Città: Milano
Messaggi: 7098
Quote:
Originariamente inviato da biowep Guarda i messaggi
Ciao, esiste qualche differenza nel tempi di esecuzione del codice in un una struttura try? Dovrebbero esserci per forza, perché altrimenti non avrebbe senso inserire solo alcune parti di codice ma tutto il programma e dovrebbe essere previsto di default, senza nemmeno essere esplicitato.
l'overhead eventuale è nulla rispetto ai vantaggi
__________________
Apple Watch Ultra + iPhone 15 Pro Max + Rog Ally + Legion Go
The_ouroboros è offline   Rispondi citando il messaggio o parte di esso
Old 08-03-2013, 14:54   #3
biowep
Member
 
L'Avatar di biowep
 
Iscritto dal: Nov 2010
Messaggi: 211
Quote:
Originariamente inviato da The_ouroboros Guarda i messaggi
l'overhead eventuale è nulla rispetto ai vantaggi
Quindi scrivere tutto il programma in un try sarebbe una buona abitudine di programmazione?
biowep è offline   Rispondi citando il messaggio o parte di esso
Old 08-03-2013, 14:56   #4
The_ouroboros
Senior Member
 
L'Avatar di The_ouroboros
 
Iscritto dal: May 2007
Città: Milano
Messaggi: 7098
Quote:
Originariamente inviato da biowep Guarda i messaggi
Quindi scrivere tutto il programma in un try sarebbe una buona abitudine di programmazione?
no, ma non stare li a farsi patemi sull'overhead di questo costrutto? sì
__________________
Apple Watch Ultra + iPhone 15 Pro Max + Rog Ally + Legion Go
The_ouroboros è offline   Rispondi citando il messaggio o parte di esso
Old 08-03-2013, 15:03   #5
clockover
Senior Member
 
L'Avatar di clockover
 
Iscritto dal: Oct 2004
Messaggi: 1945
Se non è necessario il blocco try/catch non ci sono motivi per inserirlo
StackOverflow come sempre ha delle risposte a quasi tutto --> http://stackoverflow.com/questions/1...y-catch-blocks
Quasi sicuramente ci sono altre risorse in rete e anche meglio approfondite

Qui invece un piccolo bench --> http://stackoverflow.com/questions/1...y-catch-blocks

Ps
comunque secondo me è proprio una pippa mentale pensare all'overhead del try/catch

Ultima modifica di clockover : 08-03-2013 alle 15:10.
clockover è offline   Rispondi citando il messaggio o parte di esso
Old 08-03-2013, 15:05   #6
The_ouroboros
Senior Member
 
L'Avatar di The_ouroboros
 
Iscritto dal: May 2007
Città: Milano
Messaggi: 7098
ovviamente intendevo usarlo dove serve e non tanto per usarlo.
__________________
Apple Watch Ultra + iPhone 15 Pro Max + Rog Ally + Legion Go
The_ouroboros è offline   Rispondi citando il messaggio o parte di esso
Old 08-03-2013, 15:12   #7
clockover
Senior Member
 
L'Avatar di clockover
 
Iscritto dal: Oct 2004
Messaggi: 1945
Quote:
Originariamente inviato da The_ouroboros Guarda i messaggi
ovviamente intendevo usarlo dove serve e non tanto per usarlo.
infatti oggi non riesco a esprimermi... ho bisogno di dormire
clockover è offline   Rispondi citando il messaggio o parte di esso
Old 08-03-2013, 21:34   #8
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
In effetti il discorso e' lungo.
Il problema principale e' che in caso di eccezione si deve effettuare il rollback dello stack; pertanto il compilatore deve inserire, per ogni istruzione nel try...catch che possa sollevare eccezioni anche il codice per verificare se e' stata sollevata un'eccezione ed il relativo codice di unroll dello stack.

La cosa e' piuttosto pesante, ma puo' anche essere peggio. Soprattutto se si programma in Visual C++ con una versione di Visual Studio non aggiornata.

Al tempo (per esempio, VS 2003/2005/...) le eccezioni erano codificate mediante SEH!!! In VS2003 non c'era alternativa, mentre la cosa e' stata messa opzionale nelle versioni successive per mantenere la compatibilita' con il codice precedente.

Questo ovviamente ha un grosso impatto, soprattutto sulla correttezza del codice: i crash avrebbero potuto essere benissimo nascosti e tramutati inconsapevolmente in eccezioni, con risultati disastrosi. Infatti MS si e' poi decisa a cambiare a seguito delle lamentele arrivate.
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 09-03-2013, 05:00   #9
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Non so com'è messo .NET in generale, ma in particolare in IronPython (Python per .NET) le eccezioni sono decisamente pesanti.

Mentre in Python sono abbastanza leggere, e quindi si usano alacremente.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 09-03-2013, 08:14   #10
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Quote:
Originariamente inviato da cdimauro Guarda i messaggi
Non so com'è messo .NET in generale, ma in particolare in IronPython (Python per .NET) le eccezioni sono decisamente pesanti.

Mentre in Python sono abbastanza leggere, e quindi si usano alacremente.
Molto interessante!!! Hai un'idea del motivo che rende le eccezioni di python cosi' leggere?
Immagino che ci sia una buona ottimizzazione nel caso le eccezioni siano sollevate e intercettate nella stessa funzione. Negli altri casi non ho proprio idea. Hai qualche info? (spero non un link con una spataffiata in inglese, preferisco una cosa semplificata - anche non completamente corretta, purche' renda l'idea)
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 09-03-2013, 11:01   #11
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Non è veloce di per sé, ma rispetto ad IronPython ci sono differenze abissali (mi pare di un paio di ordini di grandezza).

Informazioni non ne ho. Ho studiato il codice di CPython per quanto riguarda l'implementazione degli opcode che utilizza per inizializzare e finalizzare i blocchi di try/except/finally, e viene eseguito poco codice.

Il setup, ad esempio, richiede poche istruzioni. Molte meno rispetto a un'operazione aritmetica, per fare un esempio.

La finalizzazione è anch'essa molto semplice, e richiede generalmente poche istruzioni.

Soltanto il costrutto with è un po' più complesso, perché lì entra in gioco tutto un discorso sui contesti.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 09-03-2013, 11:44   #12
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
Quote:
Originariamente inviato da cdimauro Guarda i messaggi
Non è veloce di per sé, ma rispetto ad IronPython ci sono differenze abissali (mi pare di un paio di ordini di grandezza).

Informazioni non ne ho. Ho studiato il codice di CPython per quanto riguarda l'implementazione degli opcode che utilizza per inizializzare e finalizzare i blocchi di try/except/finally, e viene eseguito poco codice.

Il setup, ad esempio, richiede poche istruzioni. Molte meno rispetto a un'operazione aritmetica, per fare un esempio.

La finalizzazione è anch'essa molto semplice, e richiede generalmente poche istruzioni.

Soltanto il costrutto with è un po' più complesso, perché lì entra in gioco tutto un discorso sui contesti.
quel finally ha lo scopo di liberare la memoria allocata da un oggetto nel caso venga sollevata una eccezione?
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 09-03-2013, 12:05   #13
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
In alcuni casi sì. Ad esempio se l'eccezione provoca l'uscita da una o più funzioni/metodi, viene ripulito il loro stack di variabili, e dunque si perde molto più tempo rispetto a un finally (o except) eseguito in un pezzo di codice "semplice" (che non fa chiamate, o che al limite, pur facendole, le funzioni/metodi chiamati non sollevano eccezioni intercettate da quel try).
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Samsung Galaxy S25 Edge: il top di gamma ultrasottile e leggerissimo. La recensione Samsung Galaxy S25 Edge: il top di gamma ultraso...
HP Elitebook Ultra G1i 14 è il notebook compatto, potente e robusto HP Elitebook Ultra G1i 14 è il notebook c...
Microsoft Surface Pro 12 è il 2 in 1 più compatto e silenzioso Microsoft Surface Pro 12 è il 2 in 1 pi&u...
Recensione REDMAGIC Astra Gaming Tablet: che spettacolo di tablet! Recensione REDMAGIC Astra Gaming Tablet: che spe...
Dopo un mese, e 50 foto, cosa abbiamo capito della nuova Nintendo Switch 2 Dopo un mese, e 50 foto, cosa abbiamo capito del...
AI Action Plan: Trump punta su meno rego...
Aeneas: ecco l'IA che riporta in vita le...
Più skibidiboppi per tutti? Pi&ug...
Tesla, utili in calo del 23%: il secondo...
Puoi adesso bloccare il tuo PC Windows u...
xAI punta a 50 ExaFLOPS: Musk prepara un...
Il più comprato dagli appassionat...
dreame L40 Ultra 11.000Pa e lavaggio con...
Sembra un PC del 1995, ma monta una RTX ...
Giochi Xbox a 80 dollari? Microsoft ci r...
Trump voleva smembrare NVIDIA: 'Poi ho c...
Lisa Su spiega perché AMD pagher&...
La cometa interstellare 3I/ATLAS potrebb...
Un triste giorno per l'industria videolu...
Il tuo mouse ti spia? La suite di gestio...
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: 08:35.


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