Torna indietro   Hardware Upgrade Forum > Software > Programmazione

ASUS VivoBook S15 M533IA: tutto al meglio, tranne lo schermo
ASUS VivoBook S15 M533IA: tutto al meglio, tranne lo schermo
Grazie al processore AMD Ryzen 7 4700U il notebook ASUS VivoBook S15 M533IA mette a disposizione un ideale bilanciamento tra la potenza di calcolo e silenziosità di funzionamento, permettendo molte ore di lavoro e svago lontano dalla presa di corrente ad un prezzo interessante. Purtroppo la qualità dello schermo ne sconsiglia l'acquisto, anche qualora fosse proposto ad un listino più contenuto
Xbox Series S: tutto quello che c'è da sapere
Xbox Series S: tutto quello che c'è da sapere
Manca ormai poco al lancio di Xbox Series S, la console di nuova generazione che, insieme a Xbox Series X e a PlayStation 5, introdurrà nel mondo console aspetti molto importanti come SSD e Ray Tracing. Ecco in un unico articolo tutto quello che sappiamo finora
MSI RTX 3080 GAMING X TRIO 10G, Nvidia Ampere in formato maxi
MSI RTX 3080 GAMING X TRIO 10G, Nvidia Ampere in formato maxi
A tu per tu con la prima scheda video GeForce RTX 3080 "custom" giunta in redazione: ecco la nuova MSI RTX 3080 Gaming X Trio 10G. La scheda si presenta con dimensioni superiori alla Founders Edition, in virtù di un sistema di raffreddamento a tre ventole. Alimentata da tre connettori a 8 pin, non si fa mancare l'overclock di fabbrica.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 12-08-2020, 15:13   #1
pepp1995
Junior Member
 
Iscritto dal: Aug 2017
Messaggi: 3
[Java] codice non compila

Obiettivo: avere un array di un certo Tipo ClassePadre MA "riempito" con oggetti di ClassiFiglie diverse.

Ho creato una ClassePadre: Figura in cui non faccio sostanzialmente nulla ed ho definito le varie ClassiDerivate di questa classe .
Ogni ClasseDerivata ha 1 unico metodo che è una stampa.


/*DEFINISCO la CLASSE MADRE*/
public class Figura{


}


/*DEFINISCO le CLASSI FIGLIE*/
class Triangolo extends Figura{

public void disegnaTriangolo()
{
System.out.println("disegno Triangolo");
}

}


class Cerchio extends Figura{

public void disegnaCerchio()
{
System.out.println("disegno cerchio");
}

}

class Quadrato extends Figura{

public void disegnaQuadrato()
{
System.out.println("disegno quadrato");
}

}


Il vettore voglio sia inizializzato, inizializzando " in modo random" i suoi elementi con oggetti delle tre classi figlie .

import java.util.Random; //importo la Classe Random

public class GeneratoreCasualeFigure{

//metodo
public Figura GeneraFigura()
{

Random rand=new Random();
Figura x=null;
switch(rand.nextInt(3))
{
case 0:
x= new Cerchio();
break;
case 1:
x= new Quadrato();
break;
case 2:
x= new Triangolo();
break;
}

return x;
}

}


Fin qui tutto funziona nella mainClass.
A questo punto , vorrei fare una stampa del vettore che "a seconda dell'oggetto\elemento del vettore da stampare, mi chiama il metodo() di stampa di quell'oggetto"
Quindo ho definito una classe: Test

public class Test{

public void stampaVettOggFiglie(Figura[] vet,int n )
{

for(int i=0; i<n; i++)
{
switch(vet[i].getClass().getName() ) //scelgo in base al tipoRefenziato
{
case "Triangolo":
vet[i].disegnaTriangolo();
break;

case "Quadrato":
vet[i].disegnaQuadrato();
break;

case "Cerchio":
vet[i].disegnaCerchio();
break;
}
}
}


public static void main(String[] args)
{
Figura[] A= new Figura[10];

GeneratoreCasualeFigure gen= new GeneratoreCasualeFigure();

for(int i=0; i<10; i++)
A[i] = gen.GeneraFigura();


//STAMPA VETTORE riempito con oggetti di classiFiglie diverse
Test x=new Test();
x.stampaVettOggFiglie(A,3);

}

}


PROBLEMA: ho un errore di compilazione, perché il compilatore cerca i tre metodi: disegnaTriangolo(), disegnaQuadrato() , disegnaCerchio() nella ClassePadre e vede che lì non ci sono.

Tuttavia, mi aspetterei che:
<<visto che "al momento dell'invocazione del metodo: stampaVettOggFiglie() ",gli elementi vet[i] sono stati inizializzati con le reference dei rispettivi oggetti--->
- nel momento in cui faccio : vet[i].disegnaTriangolo(); sto accedendo al metodo: disegnaTriangolo() dell' oggetto vet[i] della classe Triangolo
- nel momento in cui faccio : vet[i].disegnaQuadrato(); sto accedendo al metodo: disegnaQuadrato() dell' oggetto vet[i] della classe Quadrato
- nel momento in cui faccio : vet[i].disegnaCerchio(); sto accedendo al metodo: disegnaCerchio() dell' oggetto vet[i] della classe Cerchio >>
Perché non è così?
pepp1995 è offline   Rispondi citando il messaggio o parte di esso
Old 13-08-2020, 11:24   #2
Lampo89
Junior Member
 
L'Avatar di Lampo89
 
Iscritto dal: Dec 2006
Messaggi: 13
Quote:
Originariamente inviato da pepp1995 Guarda i messaggi
Obiettivo: avere un array di un certo Tipo ClassePadre MA "riempito" con oggetti di ClassiFiglie diverse.

Ho creato una ClassePadre: Figura in cui non faccio sostanzialmente nulla ed ho definito le varie ClassiDerivate di questa classe .
Ogni ClasseDerivata ha 1 unico metodo che è una stampa.


/*DEFINISCO la CLASSE MADRE*/
public class Figura{


}


/*DEFINISCO le CLASSI FIGLIE*/
class Triangolo extends Figura{

public void disegnaTriangolo()
{
System.out.println("disegno Triangolo");
}

}


class Cerchio extends Figura{

public void disegnaCerchio()
{
System.out.println("disegno cerchio");
}

}

class Quadrato extends Figura{

public void disegnaQuadrato()
{
System.out.println("disegno quadrato");
}

}


Il vettore voglio sia inizializzato, inizializzando " in modo random" i suoi elementi con oggetti delle tre classi figlie .

import java.util.Random; //importo la Classe Random

public class GeneratoreCasualeFigure{

//metodo
public Figura GeneraFigura()
{

Random rand=new Random();
Figura x=null;
switch(rand.nextInt(3))
{
case 0:
x= new Cerchio();
break;
case 1:
x= new Quadrato();
break;
case 2:
x= new Triangolo();
break;
}

return x;
}

}


Fin qui tutto funziona nella mainClass.
A questo punto , vorrei fare una stampa del vettore che "a seconda dell'oggetto\elemento del vettore da stampare, mi chiama il metodo() di stampa di quell'oggetto"
Quindo ho definito una classe: Test

public class Test{

public void stampaVettOggFiglie(Figura[] vet,int n )
{

for(int i=0; i<n; i++)
{
switch(vet[i].getClass().getName() ) //scelgo in base al tipoRefenziato
{
case "Triangolo":
vet[i].disegnaTriangolo();
break;

case "Quadrato":
vet[i].disegnaQuadrato();
break;

case "Cerchio":
vet[i].disegnaCerchio();
break;
}
}
}


public static void main(String[] args)
{
Figura[] A= new Figura[10];

GeneratoreCasualeFigure gen= new GeneratoreCasualeFigure();

for(int i=0; i<10; i++)
A[i] = gen.GeneraFigura();


//STAMPA VETTORE riempito con oggetti di classiFiglie diverse
Test x=new Test();
x.stampaVettOggFiglie(A,3);

}

}


PROBLEMA: ho un errore di compilazione, perché il compilatore cerca i tre metodi: disegnaTriangolo(), disegnaQuadrato() , disegnaCerchio() nella ClassePadre e vede che lì non ci sono.

Tuttavia, mi aspetterei che:
<<visto che "al momento dell'invocazione del metodo: stampaVettOggFiglie() ",gli elementi vet[i] sono stati inizializzati con le reference dei rispettivi oggetti--->
- nel momento in cui faccio : vet[i].disegnaTriangolo(); sto accedendo al metodo: disegnaTriangolo() dell' oggetto vet[i] della classe Triangolo
- nel momento in cui faccio : vet[i].disegnaQuadrato(); sto accedendo al metodo: disegnaQuadrato() dell' oggetto vet[i] della classe Quadrato
- nel momento in cui faccio : vet[i].disegnaCerchio(); sto accedendo al metodo: disegnaCerchio() dell' oggetto vet[i] della classe Cerchio >>
Perché non è così?
Ciao,
vet[i] è una reference a Figure, di conseguenza potrai invocare i soli metodi che costituiscono l'interfaccia di Figure.
Stai confondendo due concetti: un conto è il tipo concreto dell'oggetto che è referenziato - che può essere uno tra un triangolo, un cerchio e un quadrato - un'altra cosa è il tipo della referenza che punta ad esso e che definisce "ciò che puoi utilizzare".
Nel tuo caso devi eseguire un cast esplicito nella opportuna classe figlia, ad es:

case "Triangolo":
((Triangolo)vet[i]).disegnaTriangolo();
break;

o ancora meglio sfruttare in maniera più efficace interfacce e polimorfismo, per es (mantenendo quasi tutti i vecchi nomi):

/*DEFINISCO la CLASSE MADRE*/
public interface Figura {
void disegna();
}

/*DEFINISCO le CLASSI FIGLIE*/
class Triangolo implements Figura {
@Override
public void disegna() {
System.out.println("disegno Triangolo");
}
}

class Cerchio implements Figura { // TODO
}

class Quadrato implements Figura { // TODO
}

// test
public class Test {
private static final int SIZE = 10;

public static void stampaVettOggFiglie(Figura[] vet) {
for (Figura f : vet) {
f.disegna();
}
}

public static void main(String[] args) {
final Figura[] A = new Figura[SIZE];
final GeneratoreCasualeFigure gen = new GeneratoreCasualeFigure();

for (int i = 0; i < SIZE; i++) {
A[i] = gen.GeneraFigura();
}

//STAMPA VETTORE riempito con oggetti di classiFiglie diverse
stampaVettOggFiglie(A);
}

}

Ultima modifica di Lampo89 : 13-08-2020 alle 11:26.
Lampo89 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


ASUS VivoBook S15 M533IA: tutto al meglio, tranne lo schermo ASUS VivoBook S15 M533IA: tutto al meglio, trann...
Xbox Series S: tutto quello che c'è da sapere Xbox Series S: tutto quello che c'è da sa...
MSI RTX 3080 GAMING X TRIO 10G, Nvidia Ampere in formato maxi MSI RTX 3080 GAMING X TRIO 10G, Nvidia Ampere in...
Nvidia GeForce RTX 3080 alla prova, l'era del ray tracing è finalmente iniziata Nvidia GeForce RTX 3080 alla prova, l'era del ra...
Sony A7c: anche in casa Sony la full frame diventa compatta. La nostra anteprima Sony A7c: anche in casa Sony la full frame diven...
Nuovi firmware per gli obiettivi Sigma N...
Libre Sense di Abbott, il sensore indoss...
Xbox Series X e Xbox Series S, al via i ...
Sconti Amazon esagerati (oltre il 70%): ...
GeForce RTX 3080: Nvidia parla di dispon...
Ottiche APS-C su fotocamere full frame? ...
Le fotografie più belle dei Comed...
Fortnite: Salva il Mondo non sarà...
Microsoft Edge può raggruppare le...
Google, ecco il nuovo speaker da meno di...
DS 7 Crossback E-Tense Louvre: arte e au...
ADATA XPG Gammix S70, SSD M.2 PCIe 4.0 c...
Cyberpunk 2077: nuove immagini per Night...
Zerologon, anche il Governo USA avvisa s...
Logitech MX Anywhere 3: ecco il nuovo ''...
Firefox 81
Google Chrome Portable
MSI Afterburner
Dropbox
K-Lite Mega Codec Pack
K-Lite Codec Pack Full
Chromium
PowerDVD
OCCT
CrystalDiskInfo
Driver NVIDIA GeForce 456.38 WHQL
Advanced SystemCare Ultimate 13
iTunes 12
Opera 71
Radeon Software Adrenalin 2020 20.9.1
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: 09:38.


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