Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a
Abbiamo potuto mettere le mani in anteprima sul nuovo monitor MSI dedicato ai giocatori: un mostro che adotta un pannello QD-OLED da 26,5 pollici con risoluzione 2560 x 1440 pixel, frequenza di aggiornamento fino a 500 Hz e tempo di risposta di 0,03 ms GtG
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro
DJI aggiorna la sua linea di droni ultraleggeri con Neo 2, un quadricottero da 160 grammi che mantiene la compattezza del predecessore ma introduce una stabilizzazione meccanica a due assi, sensori omnidirezionali e un sistema LiDAR
L'IA "seria" di Appian è diversa: inserita nei processi e rispetta dati e persone
L'IA "seria" di Appian è diversa: inserita nei processi e rispetta dati e persone
Ad Appian Europe 2025, l'azienda parla molto della sua visione di cos'è e come dovrebbe essere usata l'intelligenza artificiale: è uno strumento che va sempre adoperato dalle persone, che devono rimanere responsabili dei processi all'interno dell'azienda. Non è un giocattolo con cui sperimentare, ma un aiuto per superare le sfide di business più importanti
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 07-06-2009, 17:50   #1
e-commerce84
Senior Member
 
Iscritto dal: Feb 2009
Messaggi: 700
[JAVA] Problema con reflection, urgente :-(

Ciao,
vi prego di aiutarmi...domani esame....mi sono impicciato con questo esercizio d'esame dove c'è la reflection


Si consideri una collezione di oggetti generici e misurabili che sia omogenea (ovvero, tutti gli oggetti nella collezione sono dello stesso tipo), dinamica (ovvero, è possibile inserire e rimuovere oggetti dalla collezione) e dotata di un metodo in grado di accedere ai suoi elementi.
Si consideri un metodo cercaElemento che prende in input una tale collezione generica di oggetti C ed un oggetto obj, e cerca se nella collezione C è presente un oggetto la cui misura è uguale a quella di obj: in caso positivo il metodo restituisce l’indice di un oggetto la cui misura è uguale a quella di obj, altrimenti

a) se C contiene almeno un elemento la cui misura è minore a quella di obj, allora il metodo restituisce la lista degli elementi la cui misura è minore a quella di obj (in una forma ascelta), altrimenti

b) il metodo segnala che nessuna delle due eventualità precedenti è verificata.

Problema 1. Si richiede la progettazione del tipo di dati CollezioneOggettiMisurabili corrispondente alle specifiche sopra descritte e di tutti i tipi coinvolti, nonché la loro
implementazione in linguaggio Java. Per la classe CollezioneOggettiMisurabili si richiede la funzione di astrazione e l’invariante di rappresentazione.

Problema 2. Si richiede l’implementazione in linguaggio Java del metodo cercaElemento.


Io l'ho pensato così, ma mi impiccio in un punto e non sò che fare:

Per prima cosa definisco un'interface Misurabile che definisce dei generici oggetti misurabili che hanno in comune la capacità di misurarsi e di restituire tale valore.

Codice:
public interface Misurabile{
	/** OVERVIEW: Definisce oggetti misurabili ed implementa un metodo misura() */
	
	double misura();
}
Poi definisco una classe chiamata CollezioneDiOggettiMisurabili che implementa la collezione in modo tale che contenga solo elementi aventi tutti lo stesso tipo effettivo e che implementa le 3 operazioni richieste: inserimento di un oggetto nella collezione (viene inserito se e solo se ha lo stesso tipo effettivo degli altri oggetti eventualmente presenti nella collezione), rimozione di un oggetto dalla collezione ed accesso ad un elemento della collezione.

Proprio l'implementazione dell'ultimo metodo mi stà creando non pochi problemi e credo che bisogna usare la reflection (che abbiamo trattato l'ultima lezione molto velocemente).

Questa è la mia classe, il metodo get() non riesco ad implementarlo del tutto:

Codice:
import java.util.*;
import java.lang.*;

public class CollezioneOggettiMisurabili{

/** OVERVIEW: Rappresenta una collezione omogenea (tutti gli elementi appartenenti alla collezione devono avere lo stesso
    		  tipo effettivo) di generici oggetti Misurabile 
    		  
    		  V = {{m_1, m_2, m_3,......., m_n} dove per ogni m_i è un oggetto misurabile}
    		  O = 1) Inserisci() : Inserisce un oggetto nella collezione
    		  	  2) Elimina(): Elimina un elemento dalla collezione
    		  	  3) get(): Accede ad un determinato elemento della collezione
    		  C = 0 (non ci sono costanti significative
    		  
    		  F_a(): STATO CONCRETO -----> STATO ASTRATTO
    		  F_a([3, 5, 8]) ------> {{3, 5, 8}, che sono oggetti InteriMisurabili}
    		  
    		  I(oggetto): 1) oggetto.collezione != null (la collezione non deve mai essere null)
    		  			  2) Per ogni i oggetto.get(i) è un Misurabile (tutti gli oggetti della collezione devono essere dei Misurabile)
    		  			  3) Per ogni i oggetto.get(i) deve avere lo stesso tipo effettivo di tutti gli altri elementi della collezione
*/

	private Vector collezione;		// Per rappresentare la collezione di oggetti misurabili
	
	/** COSTRUTTORE:
		EFFECTS: Costruisce un nuovo oggetto di tipo CollezioneOggettiMisurabili che rappresenta la collezione vuota
		@param: void
		@return: Il riferimento ad un nuovo oggetto di tipo CollezioneOggettiMisurabili */
		
	public CollezioneOggettiMisurabili(){
		collezione = new Vector();					// Crea la collezione vuota
	}
	

	/** inserisci():
		EFFECTS: Se possibile inserisce un nuovo oggetto all'interno della collezione. Se la collezione è vuota, l'oggetto
				 passatogli come parametro viene inserito nella prima posizione della collezione; Se invece la collezione
				 non è vuota, il parametro verrà inserito nella collezione se e solo se ha lo stessotipo effettivo degli
				 altri elementi appartenenti alla collezione
		MODIFIES: this
		@param: Il riferimento ad un oggetto di tipo Misurabile
		@return: void */
		
	public void inserisci(Misurabile m){
		
		if(collezione.size() == 0)				// Se la collezione è vuota
			collezione.addElement(m);			// Inserisce l'oggetto referenziato dal parametro in prima posizione
			
		else{									// Se invece la collezione non è vuota
			// Controlla che l'oggetto referenziato dal parametro abbia lo stesso tipo effettivo degli oggetti nella collezione
			if(collezione.elementAt(0).getClass().isInstance(m))	// Se è vero
				collezione.addElement(m);			// Inserisce l'oggetto referenziato dal parametro in prima posizione
				
			else throw new FailureException();			// Se invece non lo è solleva una FailureException
		}
	}
	
	
	/** rimuovi():
		EFFECTS: Se possibile rimuove l'i-esimo elemento dalla collezione, non è possibile rimuovere un elemento avente 
				 posizione negativa o maggiore della dimensione della collezione
		REQUIRES: La collezione non deve essere vuota ed il parametro che indica la posizione dell'elemento da rimuovere
				  deve essere >=0 e < della dimensione della collezione
		@param: int indica la posizione dell'elemento da rimuovere
		@return: void */
		
	public void rimuovi(int i){
		
		if(i >= 0 && i <= collezione.size() && collezione != null)		// Se possibile rimuovi l'elemento lo rimuove
			collezione.remove(i);										
			
		else throw new FailureException();		// Se invece non lo è solleva una FailureException
	}
	
	/** get():
		EFFECTS: Se possibile restituisce l'i-esimo elemento dalla collezione, non è possibile restituire un elemento avente 
				 posizione negativa o maggiore della dimensione della collezione
		REQUIRES: La collezione non deve essere vuota ed il parametro che indica la posizione dell'elemento da restituire
				  deve essere >=0 e < della dimensione della collezione
		@param: int indica la posizione dell'elemento da restituire
		@return: Un oggetto di tipo Misurabile */
		

		public Misurabile get(int i){
		
		if(i >= 0 && i <= collezione.size() && collezione != null)		// Se possibile restituire l'elemento lo restituisce
			return collezione.elementAt(i);
			
		else throw new FailureException();		// Se invece non lo è solleva una FailureException
	
	}
	
}
Inizialmente il metodo get lo avevo implementato così ma poi compilando mi sono reso conto che è sicuramente sbagliato in quanto credo che il metodo elementAt restituisca un Object o comunque un generico Misurabile (confermate?) ed infatti il compilatore mi da questo errore:

Codice:
C:\Programmi\Crimson Editor\template\esercizi\esami\14-07-08>javac CollezioneOggettiMisurabili.java
CollezioneOggettiMisurabili.java:86: incompatible types
found   : java.lang.Object
required: Misurabile
                        return collezione.elementAt(i);
                                                   ^
Note: CollezioneOggettiMisurabili.java uses unchecked or unsafe operations.
Note: Recompile with -Xlint:unchecked for details.
1 error
A spanne direi che: return collezione.elementAt(i); è come se dovesse essere "castato" al tipo effettivo dell'oggetto che viene restituito e non ad un generico Object....questo a rigor di logica perchè credo che dipenda da questo il problema...

Allora guardando in giro ho capito che devo usare la reflection in qualche modo...tranne che non sò bene come fare, avevo iniziato a riscrivere il mio metodo get in questo modo:

Codice:
public Misurabile get(int i){
		
		// Metto nella variabile tipo il tipo effettivo degli oggetti contenuti nella collezione
		Class tipo = collezione.elementAt(0).getClass();
		
		if(i >= 0 && i <= collezione.size() && collezione != null)		// Se possibile restituire l'elemento lo restituisce
			return .....
			
		else throw new FailureException();		// Se invece non lo è solleva una FailureException
	
	}
In pratica voglio mettere dentro la variabile tipo il tipo effettivo degli oggetti contenuti nella mia collezione e poi vorrei ritornare un oggetto di quel tipo o qualcosa del genere...per favore mi aiutate a scrivere questo maledetto metodo get che mi sono bloccato....dai ragazzi...domani esame...se lo passo ve ne sarò eternamente grato e sopratutto non vi romperò per un bel po' con Java...

Tnx
e-commerce84 è offline   Rispondi citando il messaggio o parte di esso
Old 07-06-2009, 20:30   #2
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
Confesso candidamente di essermi perso per strada verso i due quinti del post. Provo con una "dritta", buttata un po' lì a tentoni.

Se è vero che Vector piglia e restituisce Object è vero anche che CollezioneDiOggettiMisurabili non è costretta a prendere e dare Object: può benissimo ricevere e restituire dei Misurabile.

Cioè se questo è l'unico punto in cui qualcosa è inserito in collezione:

Codice:
public void inserisci(Misurabile m) {
    collezione.add(m);
}
necessariamente vale la condizione "gli elementi di collezione sono di tipo Misurabile". E se vale questa condizione allora vale anche:

Codice:
public Misurabile get(int index) {
    Object value = collezione.get(index);
    Misurabile m = (Misurabile)value;
    return m;
}
Verso l'esterno il contratto di una classe in cui esiste il solo metodo inserici per aggiungere elementi a collezione esiste un invariante di rappresentazione degli elementi di collezione stessa (Misurabile). La presenza di questo "fatto necessariamente vero" rende necessariamente valida la conversione esplicita Misurabile x = (Misurabile)collezione.get(qualcosa). Vector.get restituisce un Object ma se io so che in quel vector ci metto solo dei Misurabile allora non può non valere la conseguenza che tutto ciò che tiro fuori da quel vector sia un Misurabile.

Spero che questo possa esserti utile. A prescindere da questo la riflessione non mi sembra entrare in gioco (se non limitatamente ad una verifica del tipo di "value" da farsi con instanceof ma, ripeto, che sia un Misurabile appare scontato).
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI C...
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro DJI Neo 2 in prova: il drone da 160 grammi guada...
L'IA "seria" di Appian è diversa: inserita nei processi e rispetta dati e persone L'IA "seria" di Appian è divers...
Polestar 3 Performance, test drive: comodità e potenza possono convivere Polestar 3 Performance, test drive: comodit&agra...
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026 Qualcomm Snapdragon X2 Elite: l'architettura del...
La sonda spaziale NASA Voyager 1 tra cir...
La navicella Shenzhou-22 ha effettuato i...
Tre astronauti europei voleranno verso l...
LG UltraGear 37G800A: 37 pollici, 4K e 1...
Stanco dei browser pieni di AI? Orion pe...
GeForce RTX 5000 custom in pericolo? NVI...
Windows Update prende il posto di Micros...
Segnali di crisi per il mercato Smart TV...
Lenovo LEGION e LOQ con NVIDIA GeForce R...
Nuova Fiat 500 ibrida al debutto. Elkann...
Ecco il primo PC da gaming basato su una...
Grok può battere i campioni di Le...
DEEBOT T50 Max Pro Gen2 e X2 Omni ai min...
Autoflight mostra il primo vertiporto ga...
TCL QD-Mini LED e QLED da 65'' crollano ...
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: 02:16.


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