Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Sony Xperia 1 VII: lo smartphone per gli appassionati di fotografia
Recensione Sony Xperia 1 VII: lo smartphone per gli appassionati di fotografia
Sony Xperia 1 VII propone un design sobrio e funzionale, con un comparto fotografico di ottimo livello caratterizzato da uno zoom continuo e prestazioni generali da top di gamma puro. Viene proposto con una personalizzazione software sobria e affidabile, ma presenta qualche criticità sul fronte ricarica rapida. Il dispositivo punta su continuità stilistica e miglioramenti mirati, rivolgendosi al solito pubblico specifico del brand giapponese.
Attenti a Poco F7: può essere il best buy del 2025. Recensione
Attenti a Poco F7: può essere il best buy del 2025. Recensione
Poco F7 5G, smartphone che punta molto sulle prestazioni grazie al processore Snapdragon 8s Gen 4 e a un display AMOLED da ben 6,83 pollici. La casa cinese mantiene la tradizione della serie F offrendo specifiche tecniche di alto livello a un prezzo competitivo, con una batteria generosissima da 6500 mAh e ricarica rapida a 90W che possono fare la differenza per gli utenti più esigenti.
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.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 13-11-2007, 09:59   #1
lovaz
Senior Member
 
L'Avatar di lovaz
 
Iscritto dal: Jul 2002
Messaggi: 4334
[JAVA] Come riconoscere se un metodo statico e' chiamato da una sottoclasse?

Salve a tutti.

Ho il problema in oggetto.
Praticamente ho una superclasse con un metodo statico che,
se non ridefinito nella sottoclasse, deve lanciare una UnsupportedOperationException.

Avevo pensato a un codice tipo
if( !???.getClass().equals(Super.class) )
throws ...
Ma ovviamente non so a cosa "attaccarmi".

Idee?
Grazie dell'attenzione.

Ultima modifica di lovaz : 13-11-2007 alle 10:16.
lovaz è offline   Rispondi citando il messaggio o parte di esso
Old 13-11-2007, 10:19   #2
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da lovaz Guarda i messaggi
Ho il problema in oggetto.
Praticamente ho una superclasse con un metodo statico che,
se non ridefinito nella sottoclasse, deve lanciare una UnsupportedOperationException.

Avevo pensato a un codice tipo
if( !(???.getClass() instanceof Super) )
throws ...
Ma ovviamente non so a cosa "attaccarmi".

Idee?
Non ce ne sono ....
Innanzitutto i metodi statici non sono soggetti a "override". Tecnicamente devono seguire comunque le stesse regole dell'override ma si parla di "hiding" invece di override.
Quando si invoca un metodo statico o lo si invoca usando il nome della classe o usando un reference (ma in tal caso conta solo ed esclusivamente il tipo del reference, non dell'oggetto).

Pertanto, su queste basi, non vedo come si possa fare quello che chiedi.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 13-11-2007, 10:29   #3
AnonimoVeneziano
Senior Member
 
L'Avatar di AnonimoVeneziano
 
Iscritto dal: Aug 2001
Città: San Francisco, CA, USA
Messaggi: 13827
Mmm, credo sia anche una cosa sbagliata a livello concettuale.

Una sottoclasse ,per definizione , ha tutte le caratteristiche e funzionalità (metodi e attributi pubblici quindi) della sua superclasse. Togliere un metodo pubblico alla sottoclasse, che è quello che vuoi fare, sarebbe una violazione di questa regola.

E' compito di colui che progetta la sottoclasse decidere se necessita o meno di ridefinire il metodo statico della superclasse (in genere i metodi statici fanno operazioni generiche , non legate all'istanza della classe , quindi è molto meno comune ridefinirli rispetto ai metodi comuni).

Ciao
__________________
GPU Compiler Engineer
AnonimoVeneziano è offline   Rispondi citando il messaggio o parte di esso
Old 13-11-2007, 10:33   #4
lovaz
Senior Member
 
L'Avatar di lovaz
 
Iscritto dal: Jul 2002
Messaggi: 4334
Capisco... cerchero' di farlo non statico, ho una mezza idea...
Grazie comunque.
lovaz è offline   Rispondi citando il messaggio o parte di esso
Old 13-11-2007, 10:54   #5
lovaz
Senior Member
 
L'Avatar di lovaz
 
Iscritto dal: Jul 2002
Messaggi: 4334
Quote:
Originariamente inviato da AnonimoVeneziano Guarda i messaggi
Mmm, credo sia anche una cosa sbagliata a livello concettuale.
...
Non mi pare

In pratica il metodo in oggetto fa parte di una classe contenitore, "quasi" un bean,
che voglio de/serializzare in una stringa del tipo
"campo1:campo2:...:campoN"

pensavo di fare un metodo statico
decode(String)
che mi costruisse un oggetto data una stringa.

Voglio (vorrei) pero' impedirne l'uso da parte di una sottoclasse
che aggiunge dei campi, in modo che se il programmatore vuole
questa serializzazione sia obbligato a fare override (o hiding) di questo
metodo (e del corrispondente non statico encode()),
dato che la codifica cambia.

Un esempio (non statico) puo' essere il metodo ListIterator.add(),
che nell'implementazione ritornata da CopyOnWriteArrayList.iterator()
lancia appunto questa eccezione.
lovaz è offline   Rispondi citando il messaggio o parte di esso
Old 13-11-2007, 11:03   #6
AnonimoVeneziano
Senior Member
 
L'Avatar di AnonimoVeneziano
 
Iscritto dal: Aug 2001
Città: San Francisco, CA, USA
Messaggi: 13827
Quote:
Originariamente inviato da lovaz Guarda i messaggi
Non mi pare

In pratica il metodo in oggetto fa parte di una classe contenitore, "quasi" un bean,
che voglio de/serializzare in una stringa del tipo
"campo1:campo2:...:campoN"

pensavo di fare un metodo statico
decode(String)
che mi costruisse un oggetto data una stringa.

Voglio (vorrei) pero' impedirne l'uso da parte di una sottoclasse
che aggiunge dei campi, in modo che se il programmatore vuole
questa serializzazione sia obbligato a fare override (o hiding) di questo
metodo (e del corrispondente non statico encode()),
dato che la codifica cambia.

Un esempio (non statico) puo' essere il metodo ListIterator.add(),
che nell'implementazione ritornata da CopyOnWriteArrayList.iterator()
lancia appunto questa eccezione.
Capisco quello che vuoi fare. In poche parole il metodo statico è un metodo "Factory" .

In genere i metodi Factory hanno proprio il problema di rendere l'ereditarietà difficile.

Le soluzioni che vedo sono due :

1 - O sposti il metodo factory all'esterno della classe creando quindi una classe di supporto tipo "SuperFactory" dentro la quale metti solo metodi statici che sono i factory della classe "Super" . Poi devi invitare chi volesse ereditare dalla classe "Super" (creando una classe "Sub" ad esempio) a farsi una propria "SubFactory" mettendo dentro gli eventuali metodi factory della classe Sub.

2 - Sposti questa funzionalità all'interno di un costruttore che inizializza i vari campi del nuovo oggetto rimuovendo i metodi factory.

Ciao
__________________
GPU Compiler Engineer
AnonimoVeneziano è offline   Rispondi citando il messaggio o parte di esso
Old 13-11-2007, 11:26   #7
lovaz
Senior Member
 
L'Avatar di lovaz
 
Iscritto dal: Jul 2002
Messaggi: 4334
Mi e' venuta in mente un'alternativa: mettere come primo "argomento"
della stringa il nome pienamente qualificato della classe da usare,
e nel metodo statico usare questo nome per caricare la classe
(Class.forName) e invocare il costruttore appropriato,
passandogli tutti gli altri campi.
Nel caso qualcosa non funzioni lanciare un'eccezione (es. ClassNotFound...)

In questo caso encode/decode andrebbero bene anche per tutte le sottoclassi,
e potrebbero essere final.

Sbaglio?
lovaz è offline   Rispondi citando il messaggio o parte di esso
Old 13-11-2007, 11:57   #8
AnonimoVeneziano
Senior Member
 
L'Avatar di AnonimoVeneziano
 
Iscritto dal: Aug 2001
Città: San Francisco, CA, USA
Messaggi: 13827
Ma hai veramente bisogno di una cosa così ? Cioè, forse non vedendo il quadro completo del problema che vuoi risolvere non capisco il perchè vuoi usare questo sistema, ma a prima vista sembra un po' macchinoso.

Che motivo hai per non utilizzare un semplice costruttore per la classe?

Ciao
__________________
GPU Compiler Engineer
AnonimoVeneziano è offline   Rispondi citando il messaggio o parte di esso
Old 14-11-2007, 10:19   #9
lovaz
Senior Member
 
L'Avatar di lovaz
 
Iscritto dal: Jul 2002
Messaggi: 4334
Praticamente devo salvare lo stato degli oggetti in un file, possibilmente leggibile anche da un umano.
Nel frattempo ho considerato l'idea di usare csv, ma ho trovato solo un driver read-only:
http://csvjdbc.sourceforge.net/

Poi come opzione vorrei mettere la possibilita' di usare JavaDB,
ma non era incluso in Java6? Non lo trovo, e non trovo neanche uno straccio
di guida introduttiva...
lovaz è offline   Rispondi citando il messaggio o parte di esso
Old 14-11-2007, 11:05   #10
lovaz
Senior Member
 
L'Avatar di lovaz
 
Iscritto dal: Jul 2002
Messaggi: 4334
Quote:
Originariamente inviato da lovaz Guarda i messaggi
... JavaDB, ma non era incluso in Java6?...
Trovato, pensavo fosse stato integrato meglio (direttamente nel jre)

Daro' un'occhiata al driver csv, magari lo estendo per la scrittura

Poi faro' un interfaccia generica su jdbc.
lovaz è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Sony Xperia 1 VII: lo smartphone per gli appassionati di fotografia Recensione Sony Xperia 1 VII: lo smartphone per ...
Attenti a Poco F7: può essere il best buy del 2025. Recensione Attenti a Poco F7: può essere il best buy...
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...
L'amministrazione Trump vorrebbe distrug...
La NASA vorrebbe realizzare un reattore ...
Oltre 1.700 km con una ricarica: l'assur...
Maxi annuncio dalla Casa Bianca: Apple p...
Microonde con grill, super venduto e app...
Pubblicazioni scientifiche false in aume...
Ecco le 100 startup che prenderanno part...
Pandora colpita da un attacco informatic...
Cooler Master MasterFrame 360 Panorama S...
Motorola e Swarovski lanciano The Brilli...
Wikipedia dichiara guerra all'IA spregiu...
Dai social ai farmaci dimagranti: il nuo...
Addio spam su WhatsApp? Ecco le nuove di...
Su Windows 11 25H2 cambierà (in p...
Per la prima volta un portatile gaming c...
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: 20:21.


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