Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Samsung Galaxy Z Fold7: un grande salto generazionale
Recensione Samsung Galaxy Z Fold7: un grande salto generazionale
Abbiamo provato per molti giorni il nuovo Z Fold7 di Samsung, un prodotto davvero interessante e costruito nei minimi dettagli. Rispetto al predecessore, cambiano parecchie cose, facendo un salto generazionale importante. Sarà lui il pieghevole di riferimento? Ecco la nostra recensione completa.
The Edge of Fate è Destiny 2.5. E questo è un problema
The Edge of Fate è Destiny 2.5. E questo è un problema
Bungie riesce a costruire una delle campagne più coinvolgenti della serie e introduce cambiamenti profondi al sistema di gioco, tra nuove stat e tier dell’equipaggiamento. Ma con risorse limitate e scelte discutibili, il vero salto evolutivo resta solo un’occasione mancata
Ryzen Threadripper 9980X e 9970X alla prova: AMD Zen 5 al massimo livello
Ryzen Threadripper 9980X e 9970X alla prova: AMD Zen 5 al massimo livello
AMD ha aggiornato l'offerta di CPU HEDT con i Ryzen Threadripper 9000 basati su architettura Zen 5. In questo articolo vediamo come si comportano i modelli con 64 e 32 core 9980X e 9970X. Venduti allo stesso prezzo dei predecessori e compatibili con il medesimo socket, le nuove proposte si candidano a essere ottimi compagni per chi è in cerca di potenza dei calcolo e tante linee PCI Express per workstation grafiche e destinate all'AI.
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: 7103
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: 7103
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: 7103
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


Recensione Samsung Galaxy Z Fold7: un grande salto generazionale Recensione Samsung Galaxy Z Fold7: un grande sal...
The Edge of Fate è Destiny 2.5. E questo è un problema The Edge of Fate è Destiny 2.5. E questo ...
Ryzen Threadripper 9980X e 9970X alla prova: AMD Zen 5 al massimo livello Ryzen Threadripper 9980X e 9970X alla prova: AMD...
Acer TravelMate P4 14: tanta sostanza per l'utente aziendale Acer TravelMate P4 14: tanta sostanza per l'uten...
Hisense M2 Pro: dove lo metti, sta. Mini proiettore laser 4K per il cinema ovunque Hisense M2 Pro: dove lo metti, sta. Mini proiett...
Amazon scatenata nel weekend: sconti sug...
Pulizia per 45 giorni senza pensieri: il...
Apple taglia il prezzo degli AirPods Pro...
Tutti i MacBook Air M4 2025 da 13 pollic...
Roborock QV 35A a 429€ o Dreame L40 Ultr...
SpaceX Starship: Ship 37 ha eseguito due...
Sharkoon punta sui case a basso costo, m...
La tua rete Wi-Fi fa pena? Questi FRITZ!...
Amazon, un weekend di fuoco per gli scon...
Ancora 3 smartwatch Amazfit in forte sco...
Sharkoon A60 RGB: dissipatore ad aria du...
HONOR 400 Pro a prezzo bomba su Amazon: ...
Offerte da non perdere: robot aspirapolv...
Apple Watch e Galaxy Watch ai minimi sto...
Il rover NASA Perseverance ha ''raccolto...
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: 14:09.


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