Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Al .NEXT 2026 di Chicago, Nutanix ha mostrato quanto sia cambiata: una piattaforma software che gestisce VM, container e carichi di lavoro IA ovunque, dall’on-premise al cloud pubblico. Con un’esecuzione rapidissima sulle partnership e sulla migrazione da VMware
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta
Xiaomi Pad 8 Pro adotta il potente Snapdragon 8 Elite all'interno di un corpo con spessore di soli 5,75 mm e pannello LCD a 144Hz flicker-free, per un tablet che può essere utilizzato con accessori dedicati di altissima qualità. Fra le caratteristiche esclusive, soprattutto per chi intende usarlo con la tastiera ufficiale, c'è la modalità Workstation di HyperOS 3, che trasforma Android in un sistema operativo con interfaccia a finestre
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 04-12-2006, 14:41   #1
diadhuit
Junior Member
 
Iscritto dal: May 2005
Messaggi: 23
[java]ereditare da interfacce

Ciao!
In un esame passato il docente aveva fatto questa domanda:
Si considerino le classi sotto riportate, tra le quali Controllo causa un errore in compilazione.
Apportare al codice indicato la minor quantità di modifiche in grado di permettere al metodo main()
di produrre in uscita i valori: 1 e -1 .
Vincolo: l’interfaccia Costante non deve essere modificata.
Codice:
interface Costante { static int VAL = 0; }

class ClsA implements Costante {
   private int k = VAL;
   public void modifica() {
      k++;
      System.out.println (k);
   }
}

class Controllo {
   private Costante handle;
   Controllo (Costante cls) { handle = cls; }
   void go() { handle.modifica(); }
}

class ClsB implements Costante {
   private int k = VAL;
   public void modifica() {
      k--;
      System.out.println (k);
   }
}

public class Callback {
   public static void main (String[] args) {
      ClsA clsA = new ClsA();
      ClsB clsB = new ClsB();
      Controllo ctr1 = new Controllo (clsA);
      ctr1.go();
      Controllo ctr2 = new Controllo (clsB);
      ctr2.go();
   }
}
Ora, io sto provando a dare una risposta, ma l'unica che riesco a trovare è modificare la classe controllo nel modo seguente:
Codice:
class Controllo {
    private ClsA handleA;
    private ClsB handleB;
    Controllo (ClsA cls) {
        handleA=cls; 
    }
    Controllo (ClsB cls) {
        handleB=cls; 
    }
    void go() {
        if (handleA!=null){
            handleA.modifica();
        }else if (handleB!=null){
            handleB.modifica();
        }
    }
}
Ma mi sembra un po' macchinosa. Sto forse tralasciando qualcosa?
Se non ci fosse il vincolo imposto, potrei inserire un semplice metodo astratto modifica() senza modificare nient'altro?
Grazie mille!
diadhuit è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2006, 15:32   #2
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da diadhuit
Ma mi sembra un po' macchinosa. Sto forse tralasciando qualcosa?
Sì, è macchinosa e stai tralasciando un dettaglio importante.

Una classe non eredita da una interfaccia .... una classe (non astratta), se implementa una interfaccia, deve implementare tutti i metodi dichiarati nella interfaccia.

Nel punto in cui fai:
void go() { handle.modifica(); }

handle è un reference di tipo Costante. 'handle' quindi deve contenere un riferimento ad una classe che implementa l'interfaccia Costante.

il metodo modifica() è effettivamente implementato dalle classi ClsA e ClsB ma non è dichiarato nella interfaccia Costante.

Quindi la cosa più semplice e valida è quella di dichiarare il metodo modifica() nella interfaccia.

Facendo così, quindi l'interfaccia Costante dice: "chi mi implementa, deve implementare il metodo modifica()". Le due classi ClsA e ClsB implementano l'interfaccia Costante (e implementano il metodo) e quindi chi ha un reference di tipo Costante, può chiamare legittimamente il metodo modifica().
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2006, 16:26   #3
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Oops.... chiedo scusa ... mi è venuto il dubbio ed ho riletto meglio:

"Vincolo: l’interfaccia Costante non deve essere modificata."

Sono partito in quarta leggendo solo il codice e non ho fatto attenzione a questa nota.

Però c'è comunque una soluzione migliore della tua (senza toccare l'interfaccia). Nella classe Controllo, prima di usare 'handle' fai un test con instanceof per verificare se l'oggetto referenziato da 'handle' è di tipo ClsA oppure ClsB e poi fai il cast e la chiamata a modifica().

Una cosa del tipo:
Codice:
void go() {
    if (handle instanceof ClsA)
        ((ClsA) handle).modifica();
    else if (handle instanceof ClsB)
        ((ClsB) handle).modifica();
}
A quest'ora della sera è l'unica cosa che mi è venuta in mente.
Daltronde, se non si può toccare l'interfaccia Costante (che sarebbe la cosa più logica e corretta), non è che ci si può inventare molto altro!
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abb...
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz ASUS ROG Swift OLED PG34WCDN recensione: il prim...
Affidabilità delle GPU NVIDIA cro...
Maxi incendio in un parcheggio BYD: fiam...
Apple potrebbe diventare il terzo produt...
L'IA aiuta i computer quantistici con i ...
Nutanix Database Platform è ora i...
iliad lancia il 5G Standalone in Italia:...
Alexa+ da oggi disponibile anche in Ital...
SpaceX Starship: Ship 39 ha eseguito il ...
Auto usate: Peugeot 3008 tra le peggiori...
YMTC, il produttore di memorie 100% cine...
I gamer rinunciano alla RAM ma non agli ...
Oltre 100 estensioni Chrome malevole rub...
Multi Frame Generation 5x e 6x anche su ...
Kraken sotto ricatto dopo due accessi in...
Meta e Broadcom: accordo fino al 2029 pe...
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: 17:21.


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