Método X Closure
ENTENDENDO AS CLOSURES NO GROOVY – PARTE 1
println "Jonatas Emidio"
Início da Dúvida
Uma das coisas que mais tem me chamado a atenção no groovy é o seu suporte à closures.
Logo passei a utiliza-las no lugar dos métodos, já que a principio a função era a mesma. No entanto me surgiu uma dúvida… Será que eu ganho ou perco desempenho utilizando-as na aplicação?
A Busca
Iniciei as consultas no google e não tive muito sucesso, em seguida postei minha duvida no grails brasil e pouco depois já tinham várias respostas. Percebi que o conteúdo que estava sendo gerado era muito rico e tive a ideia de compilar todas essas informações em um post de fácil entendimento.
A Sacada
Pois bem, para começar “métodos e closures” podem até trazer o mesmo resultado, mas eles não são a mesma coisa.
Este artigo será dividido em 3 posts, pois o mesmo possui bastante conteúdo.
-
Entendendo as Closures no Groovy;
-
Método X Closure;
-
Teste de desempenho com Closures e Métodos;
Groovy in Action
Segundo o Livro Groovy in action: closures são importantes, muito importantes, são de longe um dos recursos mais importantes do groovy.
Closure é um bloco de codígo encapsulado em um objeto. Definição tambem do Groovy in action.
Exemplo 1
Para os que estão acostumados com desenvolvimento java e já teve a oportunidade de escrever uma closure ,deve ter notado que seu fluxo lógico é diferente do tradicional, mas assim que nos acostumamos com o seu estilo de escrita os algoritmos fluem como água.
Um simples exemplo de closure utilizado na documentação do groovy é o seguinte:
def clos = { print “Hello”}
// - clos2: Onde a closure recebera algum valor na sua chamada e imprimirá o mesmo.
def clos2 = {print it}. clos2(‘Hello’) /*Onde o mesmo imprime Hello*/
Trabalhando com listas
Também da documentação do groovy, temos dois exemplos bem interessantes de closures para listas.
Suponha que você precise varrer uma determinada lista e aplicar alguma lógica em cada item antes de inseri-los em outra lista.
Pois bem… Temos basicamente duas formas simples de fazer isso no groovy.
lista: ideia 1
- 1 – Podemos utilizar o collect aplicando a logica para cada item iterado:
Definição: Foi criada uma lista com as vogais e uma lista vazia que receberá o maiúsculo de cada vogal. Neste caso o collect é utilizado para aplicar a logica ao it (variável default no groovy para closures com apenas um parâmetro – neste caso uma outra lista) e inseri-lo na lista passada por parâmetro. Logo no final teremos a seguinte lista ["A", "E", "I", "O", "U"]
def list = ['a','e','i''o','u']
def newList = []
list.collect( newList ) { it.toUpperCase() }
lista: ideia 2
- 2 – Digamos que a logica a ser aplicada a cada item é um pouco mais complicada, também podemos encapsula-la em outra closure.
def list = ['a','e','i','o','u']
def newList = []
def closAux = { it.toUpperCase() }
list.collect( newList, closAux)
Definição: Neste caso estamos trabalhando com a mesma lógica, mas aqui podemos aproveitar a segunda closure para encapsular uma lógica mais complexa a ser atribuída a cada atributo da lista iterada. Aqui, temos uma nova closure criada que atribui uma lógica (no it) para no final retorna-lo. Logo em seguida podemos chamar o collect passando a nova lista e a closure. Pronto, a logica da closure passada por parâmetro será utilizada para cada item iterado da lista e atribuindo a nova lista.
Fim
Por fim. É claro que não paramos por aqui. Closures no groovy pode se transformar em um mundo quando utilizamos a boa e velha lógica de programação em conjunto com os conceitos da linguagem.
Lembrando que este post foi só um esclarecimento de closure para dar continuidade nos próximos posts.
Contatos
Método X Closure
By jonatasemidio
Método X Closure
- 1,419