Cuando JSF resuelve una #{EL Expression} no cachea los resultados. Esto quiere decir que por cada expresión como #{user.name}, se hará una llamada al método User.getName().
Esto por sí mismo no es peligroso. Pero analicemos este caso típico
[java]
@Name(“userManager”)
public class UserManager {
public List getUserList() {
return createUserList();
}
}
[/java]
[xml]
…
#{user.name}
…
[/xml]
En este caso por cada fila de la tabla, se hará una llamada al método UserManager.getUserList() para obtener el usuario actual. Si el método UserManager.getUserList() implica una llamada a la base de datos, el tiempo de carga crece increíblemente.
Una primera solución es usar el patrón de diseño Carga Perezosa (LazyLoad).
[java]
@Name(“userManager”)
public class UserManager {
private List list;
public List getUserList() {
if (this.list == null) {
this.list = createUserList();
}
return list;
}
}
[/java]
De esta forma la lista no se crea cada vez que se la llama desde la página JSF. Pero aún así se sigue invocando el método getUserList() multitud de veces.
La mejor solución es poner la lista en el contexto de la página, y acceder a ella directamente por su nombre en el contexto en vez de por el componente al que pertenece.
Esto se puede hacer mediante la anotación @Out o la anotación @Factory
[java]
public class UserManager {
@Factory(value = “userList”, scope = ScopeType.PAGE)
public List getUserList() {
if (this.list == null) {
this.list = createUserList();
}
return list;
}
}
[/java]
[xml]
// invocamos la variable userList directamente
…
#{user.name}
…
[/xml]
0 comentarios