terça-feira, 3 de março de 2015

2.11 - Como decidir que módulos ou objetos criar e o que vai em cada?

Até onde sei, não há teoria matemática que modele módulos e objetos. Nesta poderia existir teoremas que demonstrassem que determinada estratégia é a melhor, ao menos em algum sentido.

O que sei que existe é o senso comum e a experiência (de outros e minha) em desenvolvimento de programas que aponta para algo como: métodos ou objetos que "interagem" fortemente "ficam bem" no mesmo objeto ou módulo e os que "interagem" fracamente podem ficar em objetos ou módulos separados.

A engenharia de software tem palavras de referência para isso [SCHACH,2006]:

coesão: o grau de interação dentro de um módulo;
acoplamento: o grau de interação entre dois módulos;

Ainda segundo essa referência, a melhor forma de coesão é a informacional, em que um módulo reúne métodos que operam sobre uma mesma estrutura de dados.

Maiores detalhes na própria fonte.

Na minha leitura, nesse capítulo 7, são construídos argumentos para mostrar que aplicar orientação a objetos é útil para facilitar e baratear as etapas do ciclo de desenvolvimento de um projeto de software e que isso é feito maximizando a coesão e minimizando o acoplamento. Curiosamente a melhor forma de coesão coincide com a definição de objeto.

Se existir solução definitiva, dificilmente será esta (seria como acertar na loteria), mas concordo (por experiência) que essa otimização é desejável, que orientação a objetos bem aplicada resulta em bons projetos de software.


Nenhum comentário:

Postar um comentário