Plain Old Java Object: differenze tra le versioni
Contenuto cancellato Contenuto aggiunto
Traduzione (non automatica) della parte di en:Plain Old Java Object |
Migliorato la pagina |
||
(17 versioni intermedie di 16 utenti non mostrate) | |||
Riga 1:
Nell'[[ingegneria del software]], '''''POJO''''' è un [[acronimo]] di '''Plain Old Java Object'''. Il nome è usato per accentuare che un [[Oggetto (informatica)|oggetto]] dato è un oggetto ordinario [[Java (linguaggio di programmazione)|Java]], non un oggetto speciale. Il termine fu coniato da [[Martin Fowler]], Rebecca Parsons e Josh MacKenzie
{{citazione
|Ci domandavamo perché le persone si opponessero tantissimo ad usare oggetti regolari nei loro sistemi ed abbiamo concluso che era perché gli oggetti semplici non avevano un nome accattivante. Allora gliene abbiamo dato uno che ha preso molto piede.
''We wondered why people were so against using regular objects in their systems and concluded that it was because simple objects lacked a fancy name. So we gave them one, and it's caught on very nicely.''▼
|{{Cita web|url=http://
▲
|lingua=en
}}
Il termine continua il modello di termini più vecchi per tecnologie che non usano nuove caratteristiche fantastiche, come POTS ([[Plain Old Telephone Service]]) in [[telefonia]], PODS ([[Plain Old Data Structures]]) definiti nel [[C++]] ma usanti solo caratteristiche del
{{Cita web|url=https://msdn.microsoft.com/en-us/library/cc681329.aspx|titolo=POCO Support|sito=microsoft.com|lingua=en|accesso=24 agosto 2014}}
▲Il termine continua il modello di termini più vecchi per tecnologie che non usano nuove caratteristiche fantastiche, come POTS ([[Plain Old Telephone Service]]) in [[telefonia]], PODS ([[Plain Old Data Structures]]) definiti nel [[C++]] ma usanti solo caratteristiche del linguaggio [[C (linguaggio di programmazione)|C]], e POD (Plain Old Documentation) nel [[Perl]]. L'equivalente del POJO sul [[.NET Framework]] è [[Plain Old CLR Object]] (POCO).<ref>
▲{{Cita web|url=http://msdn.microsoft.com/en-us/library/cc681329.aspx |titolo=POCO Support |sito=microsoft.com |accesso=24 agosto 2014}}
</ref> Per il [[PHP]], è Plain Old PHP Object (POPO).<ref>
{{Cita web|url=http://jan.kneschke.de/2007/2/19/typesafe-objects-in-php/
== Definizione ==
In teoria, un POJO è un oggetto Java non legato ad alcuna restrizione diversa da quelle costrette dalla specifica del linguaggio Java (Java Language Specification). In altre parole, è imperativo che un POJO:
#non estenda delle classi prespecificate, come in <
#non implementi delle interfacce prespecificate, come in <
#non contenga delle [[Annotazione (Java)|annotazioni]] prespecificate, come in<
Tuttavia, a causa di difficoltà tecniche
== Variazioni contestuali ==
=== JavaBeans ===
{{Vedi anche|JavaBean}}
Un JavaBean è un POJO che è [[Serializzazione|serializzabile]], ha un [[Costruttore (informatica)|costruttore]] senza argomenti e consente l'accesso a proprietà utilizzando [[Metodo (programmazione)|metodi]] ''getter'' e ''setter'' che seguono una semplice nomenclatura convenzionata. A causa di questa convenzione si possono fare delle semplici referenze dichiarative a proprietà arbitrarie di JavaBeans. Un codice utilizzante tale referenza dichiarativa non sa nulla del tipo del ''bean'' (oggetto singolo) e si può utilizzare il ''bean'' con molti ''framework'' senza che questi ''framework'' abbiano accesso al tipo esatto del ''bean''.
La specificazione di JavaBeans, se pienamente implementata, viola leggermente il modello POJO (come la classe deve implementare l'interfaccia <code>Serializable</code>) a essere un vero JavaBean. Molte classi di POJO ancora nominate JavaBeans non soddisfano detto requisito. A causa del fatto che <code>Serializable</code> è un'interfaccia senza metodo, questo non è un onere.
Il codice seguente mostra un esempio di un componente di [[Java Server Faces]] (JSF) avente un [[Duplex|bidirezionale]] legante a un proprietà di POJO:
<syntaxhighlight lang="xml" copy=1><h:inputText value="#{mioBean.alcunaProprieta}"/></syntaxhighlight>
La definizione del POJO può essere espresso come segue:
<syntaxhighlight lang="java" line="1" copy=1>
public class MioBean
{
private String alcunaProprieta;
public String getAlcunaProprieta()
{
return alcunaProprieta;
}
public void setAlcunaProprieta(String alcunaProprieta)
{
this.alcunaProprieta = alcunaProprieta;
}
}
</syntaxhighlight>
A causa delle convenzioni di nominare in JavaBean l'unica referenza <code>alcunaProprieta</code> può essere tradotta automaticamente al metodo <code>getAlcunaProprieta()</code> (o <code>isAlcunaProprieta()</code> se la proprietà è di [[variabile booleana|tipo booleano]]) per ottenere un valore, e al metodo <code>setAlcunaProprieta(String)</code> per mettere un valore.
== Note ==
<references/>
{{Portale|Informatica}}
[[Categoria:Java]]
|