Continuando a série sobre programação, vamos falar sobre modularização. Como dividir adequadamente um sistema? Qual a unidade ideal? Como quebrar funções? Como saber se um módulo está realmente bom? Esse artigo vai tentar responder algumas dessas questões e dar argumentos para pensarmos em muitas outras.
Um bom modulo, portanto, tem de ser projetado tendo em mente o Princípio da Caixa-Preta, deve ter um alto fan-in (ser chamado por muitos outros módulos), um baixo fan-out (chamar poucos "auxiliares"), acoplar-se com outros módulos apenas através dos dados estritamente necessários e ser coeso, executando apenas uma tarefa.
Nosso próximo artigo será sobre diagramas utilizados no projeto dos módulos. De certa forma será uma continuação deste, mas com uma abordagem totalmente diferente, totalmente gráfica.
[5] Comentário enviado por EdDeAlmeida em 06/05/2008 - 08:51h
stremer,
Tem de fazer ouvido de mercador para os caras que ficam pressionando para acelerar o trabalho. Se você foge dos esquemas bem definidos, acaba perdendo mais tempo no final.
[9] Comentário enviado por EdDeAlmeida em 07/05/2008 - 19:12h
O próximo artigo já está no forno... deve estar pronto para ser postado no início da semana que vem. Aí é só esperar a fila andar. Mais uma vez obrigado pelos comentários e pelo apoio de todos.
[11] Comentário enviado por joaomc em 09/05/2008 - 13:53h
O princípio da caixa preta é bonito na teoria, mas na prática a coisa não é bem assim. Muitas vezes você *precisa* saber o que há por trás daquele método que está chamando, para, por exemplo, saber os efeitos colaterais, se o método é thread-safe, etc.
Mas estou só sendo chato, o artigo ficou bom, parabéns :)
[12] Comentário enviado por EdDeAlmeida em 09/05/2008 - 19:43h
joaomc,
Concordo em parte. Mas saber se um método é thread-safe não viola necessariamente o princípio da caixa-preta. O que viola é escrever código que dependa do algoritmo usado por essa ou aquela função. Isso é uma violação grave, que cria dependência. A questão de ser ou não thread-safe é mais relacionada com o conhecimento dos requisitos do módulo. Vamos discutir isso quando formos falar em análise de requisitos.
rl27,
Obrigado pelo comentário. E tenho certeza que em breve estarei também lendo seus artigos aqui. Basta estudar e estar com a mente aberta para aprender.