Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Microsoft Surface Pro 12 è il 2 in 1 più compatto e silenzioso
Microsoft Surface Pro 12 è il 2 in 1 più compatto e silenzioso
Basato su piattaforma Qualcomm Snapdragon X Plus a 8 core, il nuovo Microsoft Surface Pro 12 è un notebook 2 in 1 molto compatto che punta sulla facilità di trasporto, sulla flessibilità d'uso nelle differenti configurazioni, sul funzionamento senza ventola e sull'ampia autonomia lontano dalla presa di corrente
Recensione REDMAGIC Astra Gaming Tablet: che spettacolo di tablet!
Recensione REDMAGIC Astra Gaming Tablet: che spettacolo di tablet!
Il REDMAGIC Astra Gaming Tablet rappresenta una rivoluzione nel gaming portatile, combinando un display OLED da 9,06 pollici a 165Hz con il potente Snapdragon 8 Elite e un innovativo sistema di raffreddamento Liquid Metal 2.0 in un form factor compatto da 370 grammi. Si posiziona come il tablet gaming più completo della categoria, offrendo un'esperienza di gioco senza compromessi in mobilità.
Dopo un mese, e 50 foto, cosa abbiamo capito della nuova Nintendo Switch 2
Dopo un mese, e 50 foto, cosa abbiamo capito della nuova Nintendo Switch 2
Dopo un mese di utilizzo intensivo e l'analisi di oltre 50 scatti, l'articolo offre una panoramica approfondita di Nintendo Switch 2. Vengono esaminate le caratteristiche che la definiscono, con un focus sulle nuove funzionalità e un riepilogo dettagliato delle specifiche tecniche che ne determinano le prestazioni
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 28-07-2014, 12:29   #1
ste89
Member
 
Iscritto dal: Mar 2010
Messaggi: 31
Chiarimento implementazione pattern mvc

Salve a tutti
dovrei realizzare un applicazione client e server in java, per un esame all'universita'. Leggendo i vari design pattern sono arrivato alla conclusione che il model-view-controller si quello adatto all'applicazione che dovrei creare. Ho un po' di dubbi sull'implementazione di tale pattern.
Ho gia' creato le interfacce grafiche e all'interno ho inserito una classe innestata (privata) per la gestione degli eventi, ho creato il lato server che si occupa solo della comunicazione con il database cioe' ho scritto due metodi per le query(e dovrebbe fare la parte del model). Il problema principale e' il controller non riesco a capire come gestire, leggendo anche altri post nel forum con questo pattern i controlli sui dati inseriti dovrei farli nella classe controller e non nella view, ma mi chiedo come faccio a passarglieli se sono tutti privati i campi?
ste89 è offline   Rispondi citando il messaggio o parte di esso
Old 28-07-2014, 13:08   #2
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
Di solito i dati "viaggiano" all'interno di un bean, ovvero una classe che ha i metodi set e get pubblici per ciascun campo.
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
Old 28-07-2014, 14:43   #3
ste89
Member
 
Iscritto dal: Mar 2010
Messaggi: 31
io ho una classe utente, con i relativi metodi get e set, da avvalorare prendendoli dalla gui per bean ti riferisci a questa classe?
ste89 è offline   Rispondi citando il messaggio o parte di esso
Old 28-07-2014, 15:12   #4
[Kendall]
Senior Member
 
L'Avatar di [Kendall]
 
Iscritto dal: Jul 2005
Città: Vicenza
Messaggi: 1570
Allora, solitamente nel pattern MVC (che è bene o male lo standard per quanto riguarda la programmazione di applicativi con interfaccia grafica), il "Model" sono per l'appunto tutte le classi che strutturano il tuo modello dati. Queste non hanno alcun riferimento (o comunque non dovrebbero averlo) ad altri "mattoni" del tuo programma. Sono unità stand-alone che eseguono solo il loro compito. Gestiscono i dati, effettuano operazioni su di esso, caricano, salvano, e via discorrendo.

Le View sono i puri oggetti grafici, con il solo ed unico scopo di presentare a schermo una rappresentazioni visuale del modello.
Gli oggetti grafici sono eredi delle classiche classi base View, UIView, PincoPallinoView (in base a come vengono chiamate nel framework di turno).
Possono essere create programmaticamente o essere generate da file di markup tipo xml, xaml, qml o altro, in maniera tale da poter "disegnare" l'interfaccia in maniera interattiva tramite i tool messi a disposizione dal produttore del framework. (La classica situazione in cui hai il tuo bel canvas e ci trascini dentro pulsanti, campi di testo, layout e chi più ne ha più ne metta).

I Controller sono invece la parte strutturale del programma. Spesso e volentieri nei Controller tieni riferimenti agli oggetti grafici, nonchè agli oggetti del tuo Data Model. e tramite il controller li fai dialogare tra di loro.
Per esempio quando definisci un evento, per esempio la pressione di un bottone, lo vai a fare nel controller, e tale evento andrà a scatenare un qualche effetto sul tuo modello dati, o a modificare altre parti della tua interfaccia (se il suo compito - quello del pulsante intendo - è puramente visuale, per esempio far apparire un popup).

La natura dei Controller però dipende molto dal framework che usi per la presentazione.

Nella programmazione iOS per esempio esistono classi dedicate chiate ViewController, che fanno da ponte tra la view e il modello dati.

Nella programmazione Android i controller trovano la loro incarnazione nelle Activity e nei Fragment (anche se svolgono altre funzioni ben più strutturali di un semplice Controller).

Nel tuo caso dipende da quello che stai usando per il tuo programma.

La natura del controller non è comunque sempre ben definita. O meglio, in base a come è stato strutturato il framework di turno può assumere connotazioni abbastanza diverse e non sempre riconducibili ad un unica definizione.

Ultima modifica di [Kendall] : 28-07-2014 alle 15:20.
[Kendall] è offline   Rispondi citando il messaggio o parte di esso
Old 28-07-2014, 15:26   #5
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
Quote:
Originariamente inviato da ste89 Guarda i messaggi
io ho una classe utente, con i relativi metodi get e set, da avvalorare prendendoli dalla gui per bean ti riferisci a questa classe?
No, il bean è un oggetto semplice che deve contenere i soli campi relativi ai dati che vuoi scambiare con la view. Ti faccio due semplici esempi: supponiamo che tu voglia fare una schermata di login, allora costruirai un bean con due campi, id_utente e password (e relativi metodi get e set). In una seconda schermata vuoi visualizzare l'elenco degli accessi dell'utente, avrai quindi una lista di bean "AccessoBean" che avranno dei campi tipo data, ora e ip.
Come vedi in nessuno dei due casi abbiamo passato l'oggetto di classe Utente alla view.
Il controller ha lo scopo di trasportare i dati tra view e model, ed implementare la logica delle varie procedure che costituiscono l'applicazione. Ovviamente nulla ti vieta di passare un business object direttamente alla view, però così facendo perdi delle funzionalità. Se ad esempio fai una schermata per la modifica dei dati dell'utente e passi l'oggetto di classe Utente alla view, gli attributi verranno modificati direttamente senza darti prima la possibilità di validarli. Il modo corretto invece è creare un bean "DatiUtenteBean" che consente di portare i dati dalla view al controller, quindi validarli, e se sono coerenti il controller li copia sul model.
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
Old 29-07-2014, 10:12   #6
ste89
Member
 
Iscritto dal: Mar 2010
Messaggi: 31
Quote:
Spesso e volentieri nei Controller tieni riferimenti agli oggetti grafici, e tramite il controller li fai dialogare tra di loro.
Scusa Kendall potresti chiarimi questo fatto, cioe' creo l'interfaccia, come hai detto con quello che voglio xml.. e quant'altro (utilizzo il plugins windows builder in eclipse) per correttezza tutti gli oggetti grafici sono dichiarati come attributi privati della classe, che realizza la view(jframe). Come fa' il controller ad avere dei riferimenti agli oggetti?

Quote:
Per esempio quando definisci un evento, per esempio la pressione di un bottone, lo vai a fare nel controller, e tale evento andrà a scatenare un qualche effetto sul tuo modello dati, o a modificare altre parti della tua interfaccia (se il suo compito - quello del pulsante intendo - è puramente visuale, per esempio far apparire un popup).
In questo esempio ok ho il riferimento dell'oggetto che ha scaturito l'evento ma poi tutti gli altri oggetti? non so' per esempio campi di testo e quant'altro? come faccio ad averne rifermento ed ad utiizzarli?

Il mio problema e' proprio la comunicazione tra le varie parti view e controll non tanto il model perche' come hai accennato funziona in maniera indipendente o per meglio dire quando viene chiamato.(utilizzo semplicemte gli oggetti swing, se non ho capito male utilizzano il pattern observer).

Daniels118 scusa la mia ignoranza, se non ho capito male mi suggerisci di creare delle classi adhoc proprio per il trasfermento dei dati da un componente ad un'altro giusto?
Es. se ho un'interfaccia di registrazione di un utente, creo una classe dove inserire tutti i dati la passo al controll che poi effetura i controlli sui dati, se sono giusti, li passa al model atrimenti li rifiuta giusto? e cosi per ogni schermata?

Scusate ancora ho bisogno di un altro chiarimento per quello che ho letto, potrei anche far comunicare direttamente model e view direttamente senza passare dal controll, cioe' volevo creare un interfaccia che quando la creo mostra gia' al suo interno dei valori.
ste89 è offline   Rispondi citando il messaggio o parte di esso
Old 29-07-2014, 10:33   #7
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
Deve esserci per forza un controller che, allo scaturirsi di un evento (richiesta dell'utente), legge i dati dal model e li inserisce nella view.
Per far leggere i dati direttamente alla view dovresti cablare nella view i metodi di accesso al model, perdendo quella separazione che offre il pattern mvc.
Così facendo:
- perderesti la riusabilità della view, perché sarebbero cablate per quello specifico model;
- faresti un miscuglio di codice per la gestione grafica e logica, rendendone difficile l'interpretazione.

Il fatto di fare una classe ad hoc per scambiare i dati ti consente di avere un'interfaccia ben definita tra view e controller, però volendo puoi anche utilizzare delle Map. Sarebbe anche possibile passare ogni campo come un parametro distinto nei metodi, ma potrebbero venire delle firme lunghissime, che oltre ad essere brutte, vanno ad inficiare sullo stack.
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
Old 30-07-2014, 19:40   #8
ste89
Member
 
Iscritto dal: Mar 2010
Messaggi: 31
ok grazie a entrambi per i chiarimenti penso di aver finalmente capito come strutturare il tutto
ste89 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Microsoft Surface Pro 12 è il 2 in 1 più compatto e silenzioso Microsoft Surface Pro 12 è il 2 in 1 pi&u...
Recensione REDMAGIC Astra Gaming Tablet: che spettacolo di tablet! Recensione REDMAGIC Astra Gaming Tablet: che spe...
Dopo un mese, e 50 foto, cosa abbiamo capito della nuova Nintendo Switch 2 Dopo un mese, e 50 foto, cosa abbiamo capito del...
Gigabyte Aero X16 Copilot+ PC: tanta potenza non solo per l'IA Gigabyte Aero X16 Copilot+ PC: tanta potenza non...
vivo X200 FE: il top di gamma si è fatto tascabile? vivo X200 FE: il top di gamma si è fatto ...
Scompiglio nei listini Amazon: prezzi im...
Sotto i 105€ il robot Lefant che lava, a...
Mini proiettori smart in offerta: uno co...
Smartwatch Amazfit in offerta: Balance o...
Windows XP ritorna: ecco come usarlo sub...
Arrow Lake in saldo: Intel taglia i prez...
LG C4 da 55'' a 899€ è il top per...
DJI Neo a 159€ è il mini drone pe...
Robot aspirapolvere DREAME D10 Plus Gen ...
A 109€ ha costretto Amazon a nuove scort...
Sbaraglia la concorrenza Intel, questo m...
Giappone all'attacco: ecco il primo wafe...
Cinema in Italia, svolta storica: arriva...
AMD, il bivio: vale la pena restare su A...
TikTok rilascia gratis il suo font uffic...
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: 09:45.


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