SlideShare una empresa de Scribd logo
1 de 13
Descargar para leer sin conexión
Estimativa de Métricas de Separação de 
Interesses em Processos de Refatoração  para 
            Extração de Aspectos

        Introdução ao Desenvolvimento de Software Orientado por Aspectos

                                                                           José Corrêa
                                                                           Leonardo Rodrigues
                                                                           Miquéias Souza
                                                                           Sérgio Souza
INTRODUÇÃO




   Orientado a Objetos:

       • Espalhamento de Código
           • Mesma implementação em várias classes
           • Localização de todos os Concerns a serem alterados
           • Difícil manutenibilidade
       • Código entrelaçado
           • Mistura de código
           • Dificuldade em entender a implementação
           • Alterar sem afetar outros interesses
   Orientado a Aspectos:

      • Modularização de interesses
      • Escalabilidade
      • Manutenibilidade
      • Reutilização de código
      • Maior produtividade
INTRODUÇÃO




   Dúvida:


                            Vale a pena migrar?

             Aplicação OO                         Aplicação OA
MAPEAMENTO, MÉTRICAS E IMPLEMENTAÇÃO




    Ferramenta:

    ConcernMapper
                      ConcernMetrics

    Funcionalidades
    Mapeamento lógico de interesses transversais
    Estimativa de métricas de separação de interesses




                                          Mapeamento do interesse logging usando o ConcernMetrics
MAPEAMENTO, MÉTRICAS E IMPLEMENTAÇÃO




    Funcionalidades:

       •   Mapeamento lógico de interesses transversais
           • Permite uma visão modularizada dos interesses transversais
           • Métodos e Atributos de interesses transversais

       •   Estimativa de métricas de separação de interesses
           • Calculo das métricas clássicas de separação de interesses

           1. Concern Diffusion over Operations (CDO)
               • MC onde ‘M’ representa os métodos e ‘c’ os interesses
                 concerns. Conta o número de métodos e ou adendos que
                 chamam os métodos em MC.
           2. Concern Diffusion over Components (CDC)
               • CC onde ‘C’ representa os componentes e ‘c’ os interesses
                 concerns. Conta o número de componentes que acessam os
                 componentes em CC. Componentes são classes (Sistema
                 OO) e classes e aspectos (Sistema OA).
MAPEAMENTO, MÉTRICAS E IMPLEMENTAÇÃO




    Implementação:

    Calculo de CDO e CDC:

       •   Framework ASM2 Manipulação, analise e reengenharia de bytecodes.

       Sistemas OO é direto:
          Chamadas estão incluídas fisicamente no bytecode.

       Sistemas OA exige analise:
          Identificar as chamadas que podem ser incluídas no mesmo adendo.
MAPEAMENTO, MÉTRICAS E IMPLEMENTAÇÃO




    Implementação:

    Calculo de CDO e CDC:

      Algoritmo
      t1.m(arg1) and t2.m(arg2), onde ti denota o alvo da chamada
      e argi denota seu argumento (i = 1 ou i = 2).

      As duas chamadas podem ser agrupadas em um mesmo adendo, usando
      os recursos de quantificação de AspectJ, quando as seguintes condições
      são simultaneamente válidas:

       1.   t1 e t2 são variáveis da mesma classe (ou mesma classe, no caso de métodos estáticos).
       2.   arg1 e arg2 representam o mesmo valor constante (seja ele, um inteiro, real, string, etc).
MAPEAMENTO, MÉTRICAS E IMPLEMENTAÇÃO




    Implementação:

    Calculo de CDO e CDC:

     Chamadas a start
       • Mesmo tipo (Transaction)
       • Mesmos Argumentos, valor constante (1)

    ㄨ Chamada a log
       • Diferentes argumentos (“panic” e “finished”)
ESTUDO DE CASO JSPIDER




    JSpider: (http://j-spider.sourceforge.net)

    JSpider é um robô que permite recuperar e validar páginas Web.
    Versão OO e OA (Binkley et al).

          Interesse Logging

                • Calculo de CDO.




                          Métrica CDO para o interesse logging nas versões OO e OA
ESTUDO DE CASO JSPIDER




    JSpider:(http://j-spider.sourceforge.net)




          Interesse Logging

                • Calculo de CDC.




                          Métrica CDC para o interesse logging nas versões OO e OA
ESTUDO DE CASO JSPIDER




    JSpider:(http://j-spider.sourceforge.net)

    Análise dos Resultados

          • Calculo de CDO: Diferenças de valores, por adição ou remoção de código.
          • Calculo de CDC: Sem diferenças.
Trabalhos Relacionados




     ConcernMetrics (CM) x ConcernTagger (CT):

     ConcernTagger

         • Extensão que também permite o mapeamento lógico de interesses
         transversais e elementos sintáticos. Calculando métricas como
         CDC e CDO.

         Diferenças – CM e CT

             • Identificação manual de interesses transversais. (Métodos e
             chamadas a esses métodos)

             • Calculo semi-automático

             • Não realiza estimativas de novos valores de CDO e CDC para
             “aspectização” do código OO.
Conclusão




     Conclusão:


     A ferramenta ConcernMetrics, utilizada para mapeamento de interesses
     transversais em códigos de sistemas OO, se mostrou eficiente atendendo
     a seu propósito de calcular métricas para uma possível modularização de
     interesses a ser realizada.

     Diante de analise dessas métricas, os mantenedores de software estudam
     a viabilidade de se utilizar aspectos em seus sistemas ou não.

Más contenido relacionado

Similar a Estimativa de métricas de separação de interesses

Planejamento projeto masiero
Planejamento projeto masieroPlanejamento projeto masiero
Planejamento projeto masieroMaitsudá Matos
 
Programação Oritentada a Aspecto
Programação Oritentada a AspectoProgramação Oritentada a Aspecto
Programação Oritentada a AspectoBenicio Ávila
 
Engenharia informática
Engenharia informáticaEngenharia informática
Engenharia informáticaLeYa
 
Palestra introdução a uml e casos de uso final_parte1
Palestra introdução a uml e casos de uso final_parte1Palestra introdução a uml e casos de uso final_parte1
Palestra introdução a uml e casos de uso final_parte1marcosdcmartinsss
 
Arquitetura de Computadores - Lecom - UFMG
Arquitetura de Computadores - Lecom - UFMGArquitetura de Computadores - Lecom - UFMG
Arquitetura de Computadores - Lecom - UFMGdjonatascostsa
 
Estimativa de software usando pontos de função
Estimativa de software usando pontos de funçãoEstimativa de software usando pontos de função
Estimativa de software usando pontos de funçãoClaudio Martins
 
TDC2016SP - Trilha Arquitetura Empresarial
TDC2016SP - Trilha Arquitetura EmpresarialTDC2016SP - Trilha Arquitetura Empresarial
TDC2016SP - Trilha Arquitetura Empresarialtdc-globalcode
 
Visão geral da engenharia de software qualidade de software
Visão geral da engenharia de software   qualidade de softwareVisão geral da engenharia de software   qualidade de software
Visão geral da engenharia de software qualidade de softwarejordanavy
 
Métricas e Visualização de Código-fonte
Métricas e Visualização de Código-fonteMétricas e Visualização de Código-fonte
Métricas e Visualização de Código-fonteMarcilio Valois
 
Pesquisa e Conceituação de Sistemas - Metodologia
Pesquisa e Conceituação de Sistemas - MetodologiaPesquisa e Conceituação de Sistemas - Metodologia
Pesquisa e Conceituação de Sistemas - MetodologiaAntonio Sallum Librelato
 
Dev rioclaro gerenciando o ciclo de vida das suas aplicações em larga escal
Dev rioclaro   gerenciando o ciclo de vida das suas aplicações em larga escalDev rioclaro   gerenciando o ciclo de vida das suas aplicações em larga escal
Dev rioclaro gerenciando o ciclo de vida das suas aplicações em larga escalLuiz Guilherme Bauer Fraga Moreira
 
Visão geral da engenharia de software qualidade de software
Visão geral da engenharia de software   qualidade de softwareVisão geral da engenharia de software   qualidade de software
Visão geral da engenharia de software qualidade de softwarejordanavy
 

Similar a Estimativa de métricas de separação de interesses (20)

Projeto de Software
Projeto de SoftwareProjeto de Software
Projeto de Software
 
ContextLongMethod - CBSOFT 2016 - TOOLS
ContextLongMethod - CBSOFT 2016 - TOOLSContextLongMethod - CBSOFT 2016 - TOOLS
ContextLongMethod - CBSOFT 2016 - TOOLS
 
Planejamento projeto masiero
Planejamento projeto masieroPlanejamento projeto masiero
Planejamento projeto masiero
 
Programação Oritentada a Aspecto
Programação Oritentada a AspectoProgramação Oritentada a Aspecto
Programação Oritentada a Aspecto
 
Usp Ufba Qualidade De Codigo
Usp Ufba Qualidade De CodigoUsp Ufba Qualidade De Codigo
Usp Ufba Qualidade De Codigo
 
Aula02.pptx
Aula02.pptxAula02.pptx
Aula02.pptx
 
Pesquisa Operacional
Pesquisa OperacionalPesquisa Operacional
Pesquisa Operacional
 
Engenharia informática
Engenharia informáticaEngenharia informática
Engenharia informática
 
Palestra introdução a uml e casos de uso final_parte1
Palestra introdução a uml e casos de uso final_parte1Palestra introdução a uml e casos de uso final_parte1
Palestra introdução a uml e casos de uso final_parte1
 
Computacao
ComputacaoComputacao
Computacao
 
Arquitetura de Computadores - Lecom - UFMG
Arquitetura de Computadores - Lecom - UFMGArquitetura de Computadores - Lecom - UFMG
Arquitetura de Computadores - Lecom - UFMG
 
Estimativa de software usando pontos de função
Estimativa de software usando pontos de funçãoEstimativa de software usando pontos de função
Estimativa de software usando pontos de função
 
TDC2016SP - Trilha Arquitetura Empresarial
TDC2016SP - Trilha Arquitetura EmpresarialTDC2016SP - Trilha Arquitetura Empresarial
TDC2016SP - Trilha Arquitetura Empresarial
 
Visão geral da engenharia de software qualidade de software
Visão geral da engenharia de software   qualidade de softwareVisão geral da engenharia de software   qualidade de software
Visão geral da engenharia de software qualidade de software
 
Métricas e Visualização de Código-fonte
Métricas e Visualização de Código-fonteMétricas e Visualização de Código-fonte
Métricas e Visualização de Código-fonte
 
Aula1 dia 22 02 2022.pdf
Aula1  dia 22 02 2022.pdfAula1  dia 22 02 2022.pdf
Aula1 dia 22 02 2022.pdf
 
Pesquisa e Conceituação de Sistemas - Metodologia
Pesquisa e Conceituação de Sistemas - MetodologiaPesquisa e Conceituação de Sistemas - Metodologia
Pesquisa e Conceituação de Sistemas - Metodologia
 
Dev rioclaro gerenciando o ciclo de vida das suas aplicações em larga escal
Dev rioclaro   gerenciando o ciclo de vida das suas aplicações em larga escalDev rioclaro   gerenciando o ciclo de vida das suas aplicações em larga escal
Dev rioclaro gerenciando o ciclo de vida das suas aplicações em larga escal
 
Visão geral da engenharia de software qualidade de software
Visão geral da engenharia de software   qualidade de softwareVisão geral da engenharia de software   qualidade de software
Visão geral da engenharia de software qualidade de software
 
Extreme Programming
Extreme ProgrammingExtreme Programming
Extreme Programming
 

Más de SergioSouza

Banco de Dados Temporais - Temporal DataBase
Banco de Dados Temporais - Temporal DataBaseBanco de Dados Temporais - Temporal DataBase
Banco de Dados Temporais - Temporal DataBaseSergioSouza
 
Ubuntu 8.04 LTS 2008
Ubuntu 8.04 LTS 2008Ubuntu 8.04 LTS 2008
Ubuntu 8.04 LTS 2008SergioSouza
 
Dispositivos [Entrada E SaíDa]
Dispositivos [Entrada E SaíDa]Dispositivos [Entrada E SaíDa]
Dispositivos [Entrada E SaíDa]SergioSouza
 
Dispositivos de [Entrada E SaíDa]
Dispositivos de [Entrada E SaíDa]Dispositivos de [Entrada E SaíDa]
Dispositivos de [Entrada E SaíDa]SergioSouza
 
ProteçãO Juridica Do Software
ProteçãO Juridica Do SoftwareProteçãO Juridica Do Software
ProteçãO Juridica Do SoftwareSergioSouza
 
Oracle EXPLICAÇÕES EM PDF
Oracle EXPLICAÇÕES EM PDFOracle EXPLICAÇÕES EM PDF
Oracle EXPLICAÇÕES EM PDFSergioSouza
 
SISTEMAS OPERACIONAIS
SISTEMAS OPERACIONAISSISTEMAS OPERACIONAIS
SISTEMAS OPERACIONAISSergioSouza
 
Software Aplicativo
Software AplicativoSoftware Aplicativo
Software AplicativoSergioSouza
 
Oracle [Metodologia]
Oracle [Metodologia]Oracle [Metodologia]
Oracle [Metodologia]SergioSouza
 
Microsoft Surface
Microsoft SurfaceMicrosoft Surface
Microsoft SurfaceSergioSouza
 

Más de SergioSouza (11)

Banco de Dados Temporais - Temporal DataBase
Banco de Dados Temporais - Temporal DataBaseBanco de Dados Temporais - Temporal DataBase
Banco de Dados Temporais - Temporal DataBase
 
Ubuntu 8.04 LTS 2008
Ubuntu 8.04 LTS 2008Ubuntu 8.04 LTS 2008
Ubuntu 8.04 LTS 2008
 
Dispositivos [Entrada E SaíDa]
Dispositivos [Entrada E SaíDa]Dispositivos [Entrada E SaíDa]
Dispositivos [Entrada E SaíDa]
 
Dispositivos de [Entrada E SaíDa]
Dispositivos de [Entrada E SaíDa]Dispositivos de [Entrada E SaíDa]
Dispositivos de [Entrada E SaíDa]
 
Uml Para Web
Uml Para WebUml Para Web
Uml Para Web
 
ProteçãO Juridica Do Software
ProteçãO Juridica Do SoftwareProteçãO Juridica Do Software
ProteçãO Juridica Do Software
 
Oracle EXPLICAÇÕES EM PDF
Oracle EXPLICAÇÕES EM PDFOracle EXPLICAÇÕES EM PDF
Oracle EXPLICAÇÕES EM PDF
 
SISTEMAS OPERACIONAIS
SISTEMAS OPERACIONAISSISTEMAS OPERACIONAIS
SISTEMAS OPERACIONAIS
 
Software Aplicativo
Software AplicativoSoftware Aplicativo
Software Aplicativo
 
Oracle [Metodologia]
Oracle [Metodologia]Oracle [Metodologia]
Oracle [Metodologia]
 
Microsoft Surface
Microsoft SurfaceMicrosoft Surface
Microsoft Surface
 

Estimativa de métricas de separação de interesses

  • 1. Estimativa de Métricas de Separação de  Interesses em Processos de Refatoração  para  Extração de Aspectos Introdução ao Desenvolvimento de Software Orientado por Aspectos José Corrêa Leonardo Rodrigues Miquéias Souza Sérgio Souza
  • 2. INTRODUÇÃO Orientado a Objetos: • Espalhamento de Código • Mesma implementação em várias classes • Localização de todos os Concerns a serem alterados • Difícil manutenibilidade • Código entrelaçado • Mistura de código • Dificuldade em entender a implementação • Alterar sem afetar outros interesses Orientado a Aspectos: • Modularização de interesses • Escalabilidade • Manutenibilidade • Reutilização de código • Maior produtividade
  • 3. INTRODUÇÃO Dúvida: Vale a pena migrar? Aplicação OO Aplicação OA
  • 4. MAPEAMENTO, MÉTRICAS E IMPLEMENTAÇÃO Ferramenta: ConcernMapper ConcernMetrics Funcionalidades Mapeamento lógico de interesses transversais Estimativa de métricas de separação de interesses Mapeamento do interesse logging usando o ConcernMetrics
  • 5. MAPEAMENTO, MÉTRICAS E IMPLEMENTAÇÃO Funcionalidades: • Mapeamento lógico de interesses transversais • Permite uma visão modularizada dos interesses transversais • Métodos e Atributos de interesses transversais • Estimativa de métricas de separação de interesses • Calculo das métricas clássicas de separação de interesses 1. Concern Diffusion over Operations (CDO) • MC onde ‘M’ representa os métodos e ‘c’ os interesses concerns. Conta o número de métodos e ou adendos que chamam os métodos em MC. 2. Concern Diffusion over Components (CDC) • CC onde ‘C’ representa os componentes e ‘c’ os interesses concerns. Conta o número de componentes que acessam os componentes em CC. Componentes são classes (Sistema OO) e classes e aspectos (Sistema OA).
  • 6. MAPEAMENTO, MÉTRICAS E IMPLEMENTAÇÃO Implementação: Calculo de CDO e CDC: • Framework ASM2 Manipulação, analise e reengenharia de bytecodes. Sistemas OO é direto: Chamadas estão incluídas fisicamente no bytecode. Sistemas OA exige analise: Identificar as chamadas que podem ser incluídas no mesmo adendo.
  • 7. MAPEAMENTO, MÉTRICAS E IMPLEMENTAÇÃO Implementação: Calculo de CDO e CDC: Algoritmo t1.m(arg1) and t2.m(arg2), onde ti denota o alvo da chamada e argi denota seu argumento (i = 1 ou i = 2). As duas chamadas podem ser agrupadas em um mesmo adendo, usando os recursos de quantificação de AspectJ, quando as seguintes condições são simultaneamente válidas: 1. t1 e t2 são variáveis da mesma classe (ou mesma classe, no caso de métodos estáticos). 2. arg1 e arg2 representam o mesmo valor constante (seja ele, um inteiro, real, string, etc).
  • 8. MAPEAMENTO, MÉTRICAS E IMPLEMENTAÇÃO Implementação: Calculo de CDO e CDC:  Chamadas a start • Mesmo tipo (Transaction) • Mesmos Argumentos, valor constante (1) ㄨ Chamada a log • Diferentes argumentos (“panic” e “finished”)
  • 9. ESTUDO DE CASO JSPIDER JSpider: (http://j-spider.sourceforge.net) JSpider é um robô que permite recuperar e validar páginas Web. Versão OO e OA (Binkley et al). Interesse Logging • Calculo de CDO. Métrica CDO para o interesse logging nas versões OO e OA
  • 10. ESTUDO DE CASO JSPIDER JSpider:(http://j-spider.sourceforge.net) Interesse Logging • Calculo de CDC. Métrica CDC para o interesse logging nas versões OO e OA
  • 11. ESTUDO DE CASO JSPIDER JSpider:(http://j-spider.sourceforge.net) Análise dos Resultados • Calculo de CDO: Diferenças de valores, por adição ou remoção de código. • Calculo de CDC: Sem diferenças.
  • 12. Trabalhos Relacionados ConcernMetrics (CM) x ConcernTagger (CT): ConcernTagger • Extensão que também permite o mapeamento lógico de interesses transversais e elementos sintáticos. Calculando métricas como CDC e CDO. Diferenças – CM e CT • Identificação manual de interesses transversais. (Métodos e chamadas a esses métodos) • Calculo semi-automático • Não realiza estimativas de novos valores de CDO e CDC para “aspectização” do código OO.
  • 13. Conclusão Conclusão: A ferramenta ConcernMetrics, utilizada para mapeamento de interesses transversais em códigos de sistemas OO, se mostrou eficiente atendendo a seu propósito de calcular métricas para uma possível modularização de interesses a ser realizada. Diante de analise dessas métricas, os mantenedores de software estudam a viabilidade de se utilizar aspectos em seus sistemas ou não.