terça-feira, 9 de fevereiro de 2010
Busca  
Porta 80 Web Hosting
 :: Acessibilidade
Ir para conteúdo principal: ALT + 1
 :: Participe
Seja um autor de CD/DVD de Treinamento
Publique um artigo
Publique uma oportunidade
Publique uma notícia
Publique um curso
Publique uma dica
Publique um código
 :: Informativo
Receba nossos informativos por e-mail.
E-mail:   
 
Digite a palavra abaixo:  
 
 
 :: Oportunidades
Cadastrar oportunidades
Gerenciar suas oportunidades
Cadastrar nova empresa
 :: Especiais
Básico de C++
C++ Builder
Curso ASP.NET 3.5 em VB.NET e C#
Guia Prático de HTML
Testes com Visual Studio Team System 2008
 :: Desenvolvimento
ActionScript
ADO.NET
ASP
ASP.NET
Automação Comercial
C#
C/C++
Coldfusion
CSS
Delphi
Disp. Móveis
HTML
Java
Javascript
LSL (Second Life)
Modelagem
PHP
Python
Sharepoint
Silverlight
SQL
VBA (Office)
Visual Basic
Visual Basic .NET
Visual Fox Pro
WCF/WPF
Web Services
XML
 :: Infra
BizTalk Server
CRM
Exchange Server
ForeFront / Antigen / IAG
Interoperabilidade
ISA Server
Linux
MOF
MS Dynamics CRM
Network
OCS / LCS
Outlook
Powershell e Scripts
Redes
Segurança
System Center e Gerenciamento
Virtualização
Windows
Windows Server
 :: Banco de Dados
Access
Caché
Firebird
Interbase
MySQL
Oracle
SQL Server
Sybase
 :: Gerência
Arquitetura
Ciclo de Vida de Desenvolvimento
Controle de Versão
Estimativas
Metodologias
MOF
Qualidade e Testes
 :: Design
Corel
Flash
Photopaint
Photoshop
 :: Livros
Análise Sistemas
Aplicativos
Banco de Dados
Certificação
Design e CAD
Gerência
Hardware
Internet
Programação
Programação Web
Rede
Segurança
Servidores
Sistemas Operacionais
 :: CDs/DVDs
Desenvolvimento
Infra
Design
 :: E-Books
.NET 2.0 (VS 2005)
.NET 1.1 (VS 2003)
SQL Server
Excel 2007
Excel 2003
Access 2003
ASP 3.0
Delphi
Java
Artigos


MVP Profile
Iniciando em boas práticas de programação
Por: Fabio Camara
MVP VSTS, MCT, MCP, MCSD, MCTS, MCPITP, MCPD, MSF Practitioner, Certified SCRUM Master, Certified ITIL Foundations. Escreveu mais de 15 livros nesta última década. Atua como consultor de produtividade em desenvolvimento de projetos e professor de disciplinas ágeis de engenharia de software. Pode ser localizado no site http://www.fcamara.com.br.
Feed de artigos.
Feed de artigos deste autor.
Gere seu feed personalizado  
Iniciando em boas práticas de programação
Publicado em: 07/06/2003

Na maioria das discussões que participei acerca do assunto "boas práticas ou qualidade em escrita de código fonte", percebi que se não interrompêssemos as manifestações mais inflamadas o resultado continuaria muito distante de um consenso. Em outras palavras, cada um tem uma posição muito individual sobre a questão.

Realmente o assunto é polêmico na essência, pois o que é qualidade para você?

Na intenção de apresentar minhas posições pessoais, escrevo nas linhas seguintes alguns dos conceitos que a prática de 16 anos de programação consolidaram em minha forma de escrever código fonte.

Endentação

A primeira questão sobre o assunto endentação que podemos citar é sobre o número de espaços entre os níveis. Por exemplo, o Visual Studio.NET 2003 sugere como default 4 espaços conforme podemos comprovar na imagem abaixo.

Na época que os monitores e as placas de vídeo não eram tão poderosos, eu particularmente gostava de utilizar dois espaços para a endentação. No final dos anos 90 eu já tinha aderido a 3 espaços e esta é a minha opinião até hoje.

A próxima questão pode ser o tamanho máximo de uma linha de código fonte. Neste quesito defendo que se deve evitar ao máximo escrever linhas com mais de 80 posições entre espaços e caracteres. A idéia é facilitar a compreensão do código e se possível visualizar a linha inteira em seu editor de código.

Alguns trechos de código podem ficar muito extensos e você deverá encarar o dilema de quebrar a linha. Eu naturalmente não gosto de quebrar linhas de código, entretanto em situações necessárias aplico os seguintes princípios:

  • Quebrar a linha após uma vírgula;
  • Quebrar a linha após um operador;
  • Alinhar a nova linha no inicio da expressão no mesmo nível da linha anterior.
Exemplos:
longMethodCall(expr1, expr2, expr3,
  expr4, expr5);
e
var = a * b / (c - g + f) +
4 * z;

Outra premissa importante é a utilização de espaços em branco para endentação. Seja qual for sua opinião sobre esta questão, exponho a minha mais veementemente: _ Não use espaços em branco para endentação, use tabulação!

Motivos: Dos trilhões de motivos existentes, destaco a facilidade de incrementar e decrementar blocos de código através de atalhos de teclas do editor de código.

Comentários

Das muitas funcionalidades fascinantes do Visual Studio.NET, a de transformar comentários em documentação de código é realmente impressionante. Em face disso, se você tem esta necessidade, utilize as três barras "///" e seja feliz. Entretanto, para comentários que não necessitam serem publicados, quero apresentar algumas sugestões.

Baseado na preocupação que muito provavelmente o comentário é importante para você ou outra pessoa ser orientada sobre a manutenção de um código fonte, chamo a atenção à forma de destacar o comentário. Por exemplo, comentários com mais de uma linha poderiam ser assim:

/* Line 1
   Line 2
   Line 3 */

Porém conforme os critérios que destaquei, sugiro que seja desta forma:

/* Line 1
 * Line 2
 * Line 3
 */
 
Fundamentalmente a questão é visual.

Para comentários de uma linha somente, tenho a seguinte opinião. Ou o comentário deve uma espécie de marcador de loops ou não deve ser aplicado. A questão é que como exposto em linhas anteriores, os comentários devem chamar a atenção visando facilitar e direcionar a manutenção. Somente justifica-se um comentário de uma linha quando você necessita marcar dentro de um bloco de código o início de um nível de endentação ou loop. Exemplo:

//Verifica se somente uma string foi entrada
if(args.Length==1)
	Console.WriteLine(args[0]);
else
{
	ArgumentOutOfRangeException ex; 
	ex = new ArgumentOutOfRangeException("Utilize somente uma string");
	throw(ex); 
}

No exemplo acima utilizamos o comentário de uma linha com duas barras "//" para explicar um bloco de código e marcar o seu nível de endentação. Do trecho aonde este código exemplo foi retirado existiam outras linhas de código antes e depois do bloco if / else.

Outra boa aplicação para comentários de uma linha é a explicação de uma declaração. Por exemplo:

int levelStatus; // nível do status
int sizeStatus; // tamanho do status

Declarações

Sendo oportunista, declarar variáveis também deve apresentar uma preocupação com a visibilidade. Por exemplo, eu não aconselho a seguinte declaração:

int a, b;

Pode parecer exagero mas quando outro desenvolvedor for manusear seu código fonte vai apreciar se encontrar a mesma declaração da seguinte forma:

int a; // Valor de entrada 1
int b; // Valor de entrada 2

Para ser mais sincero e apresentar mais um conceito, tente sempre inicializar suas variáveis no local aonde são declaradas. Sabemos que nem sempre isto é possível, contudo bastante recomendável. Exemplo:

int a = 1; Valor de entrada 1

Permita-me um comentário adicional, não estou aconselhando nomear uma variável inteira com "a", os exemplos anteriores visam explanar outras questões.

Nomear Variáveis

Sobre este tópico, após muitas demoradas discussões com meu amigo Mauro Sant'Anna, concordamos sobre os seguintes pontos:

  • Não utilizar notação húngara. A notação é útil somente para nomear componentes e, mesmo assim, quando existe a necessidade de identificação facilitada do mesmo. Contudo se você não possui um padrão para nomear componentes, de nada adiantará utilizar a notação húngara.
  • Coloque nomes da forma mais clara possível, visando facilitar a compreensão da finalidade da variável. Em nomes compostos, faça combinações entre caracteres maiúsculos e minúsculos.
Exemplos:
string nomeUsuario;
int tempoIntervaloPadrao;

Finalizo esta matéria com a sensação que podia escrever muito mais, contudo com a restrição de tamanho imposta pelas regras estabelecidas. Agregando um valor adicional, a seguir uma sugestão de nomes de componentes conforme a notação húngara.

Nomes para componentes (notação húngara)

Windows Forms

Fabio Camara, MCP, MCSA, MCAD Charter, MCDBA e MCSD.NET - É Diretor da Architettura Soluções em Tecnologia. Escreveu os livros "Projetos com Windows DNA e .NET", "Dominando o Visual Studio.NET com C#" e "Orientação a Objeto com .NET" dentre outros, editados pela Visual Books Editora. Pode ser contatado pela home page C# Br (http://www.csharpbr.com.br).


 

Conheça os produtos do autor Fabio Camara

Inclua um comentário sobre o artigo Topo
Elogios e críticas são muito bem vindos, porém o comentário deve ter referência ao artigo em pauta.
O portal e o autor agradecem.
Nome:    
E-mail:      
Comentários:    
Digite a palavra abaixo:  
Para dúvidas técnicas, NÃO UTILIZE ESTE ESPAÇO, utilize nosso fórum de discussão.
http://linhadecodigo.com.br/cs2/forum
 
Comentários sobre o artigo Ver Todos comentários
queria saber se o senhor naum tem algo ae
sobre
-declaração de variavel
*função (metodos)

-comandos
*comparação >if, switch
*repetição > do, while, for

-registros
-classes

por favor to com alguns problemas!!

muito obrigado pela atenção!
Quem enviou: vitor caetano
Postado em: 12/02/2007 00:00:00
"não use espaço em branco para identação, use tabulação"

? rs q nojo, nunca façam isso rs

Usar espaço em branco para identar, na minha opnião, é a prática mais primitiva para se identar um documento. Imagine se vc precisar aumentar o espaço. Se não utilizar tabulação terá que adicionar espaço em todos os pontos. Desculpe mas usar espaços para esse fim me parece prática de iniciante.
Quem enviou: Mário Santos
Postado em: 19/10/2006 00:00:00
"não use espaço em branco para identação, use tabulação"

? rs q nojo, nunca façam isso rs

Bom, tenho todo respeito pelo seu tempo como programador, afinal tenho apenas a metade dos anos com programação.
Achei seu artigo muito bom, pois tratou realmente de um assunto polêmico.
Acredito que definir boas práticas de programação não seja tão dificil, quando se segue uma padronização. que pode ser conseguida com experiêntes programadores e pelas empresas responsaveis pelas ferramentas de programação, e definindo as regras para a equipe. No meu caso eu sigo o padrão da borland, lógico que ninguem dita como alguem deve fazer e sim indica a forma que acha melhor se fazer. No seu artigo eu concordo com 95% das suas experiências, pois eu tb adoto, soh a tabulação que não gostei rs ^_^, eu recomendo dois espaços, acredito q seja o necessário para ter uma boa leitura.

No mais parabéns pelo artigo, é sempre bom encontrar boa leitura.

JB
Quem enviou: JB
Postado em: 17/09/2006 00:00:00
Outros artigos do autor Topo
Introduzindo Conceitos de Testes Comportamentais
A metodologia ideal para projetos de software
Uma metodologia ágil - SCRUM
Dez perguntas sobre MSF
SDLC – Software Development Life Cycle
Eu uso metodologia ágil, e você?
MSF Essentials e MSF Agile
Uma nova ótica para Gerente de Projetos
Experimente um projeto ágil
MSF na prática - Controlando um projeto com bandeiras
Seus problemas acabaram!
Quanto tempo vai durar seu software?
MSF e CMMI não são inimigos
Os princípios de liderança do MSF, em exemplos
TechEd 2006 - Boston / EUA: Acabou o evento, mas as tecnologias continuam...
TechEd 2006 - Boston / EUA: Centro das atenções – Vista, Office 2007, Sharepoint, VSTS...
TechEd 2006 - Boston / EUA: Coisas legais e coisas ruins
TechEd 2006 - Boston / EUA: Não tem feriado aqui – Windows Vista, VSTS e MSF o dia inteiro
TechEd 2006 - Boston / EUA: Tem alguém trabalhando no Delphi?
TechEd 2006 - Boston / EUA: As palestras de VSTS no TechED 2006
TechEd 2006 - Boston / EUA: O jogo do Brasil no TechED Boston
TechEd 2006 - Boston / EUA: Jantar com VSTS Product Manager Team
TechEd 2006 - Boston / EUA: Começou o Tech ED 2006
TechEd 2006 - Boston / EUA: A caminho de Boston – Tech ED 2006
Conhecendo o Visual Studio Team System Source Control
O que há de novo no MSF
Estratégia para Entrevistas - LTI - Levantamento Técnico Inicial
Projeto é amor, metodologia é poesia
Processos Ágeis e MSF
Quem mexeu no meu código?
Quando o compilador faz a diferença?
Diagramas de classes - um exemplo funcional com Visio Enterprise Architecture 2003 e C#
Moda ou .NET? - Conheça a opinião do autor
Do Basic ao .NET – uma revisão literária
Independência de Plataforma - Portabilidade a lá .Net
O processo de compilação no C#
A calculadora em C#
Personalizando o Text Editor
Compiladores Alternativos
Comentários XML no Visual Studio.NET
Conhecendo o Visual Studio .NET
Artigos relacionados Topo
Compactação de ViewState em ASP.NET - Parte 2 (Colocando na Session)
Escopo e nível de acessos no C#
Encriptando valores passados por QueryString
Array, ArrayList e List(T): O que devemos saber?
Truques em coleções com LINQ e C# 3.0 - Parte 1
Descubra os Delegates "Show de Bola"
Tratamento de excessões em aplicações N-Tier
Generics com C# e .NET 2.0
Explorando as Coleções do .NET Framework - Parte 2
Explorando as Coleções do .NET Framework - Parte 1
Explorando alguns Delegates do C# 2.0: Predicates, Converter, Comparison e Action
C# 4.0 - Tipos Dinâmicos
Delegates e eventos no C# 2.0 - Parte 2
Delegates e eventos no C# 2.0 - Parte 1
Compactação com GZipStream e DeflateStream
Resolva seus problemas do dia-a-dia com Elevate
Criando e Lendo Cookie
Avaliando regras de negócio dinamicamente em C#
Integrando sua Aplicação .Net com Twitter
C# 4.0
Adicionando Menu no DataGridView
Persistindo TreeView no Banco de Dados
MP3 player com DirectX
Mensagem em JavaScript com .NET
Reproduzindo mp3 no .NET com C#
Receitas para o fim de ano para empresas de software
Sobrecarga, Herança, Polimorfismo e Exceção em C#
Qual a razão para incentivar as comunidades técnicas?
Visual Studio e seus Containers
Comparativo de performance: LINQ, Lambda e Dynamic LINQ
Produtos relacionados Topo
Pacote: Promoção: Portal de Vídeos .Net + CD Novidades das Linguagens (válido somente para pagamento via boleto bancário)
Pacote: Promoção Linq To SQL (válido somente para pagamento via boleto bancário)
Livro: Programando C# 3.0 - 5º Edição
Livro: Crystal Reports 2008 - O Guia Completo
Livro: C# 2008 Para Leigos
Livro: Microsoft Visual C# 2008 Express Edition - Aprenda na Prática
CD/DVD: DVD de Treinamento LINQ TO SQL e Entity Framework Avançado
Livro: Profissional C# e a Plataforma .NET 3.5 Curso Completo
Pacote: Pacote promocional Linq to SQL
CD/DVD: DVD de Treinamento E-Commerce com Visual Web Developer
Livro: Programando .NET 3.5
Livro: LINQ e C# 3.0 - A Solução em Consultas para Desenvolvedores
Livro: LINQ em Ação
CD/DVD: DVD de Treinamento - Crie uma aplicação ASP.NET com LINQ TO SQL
Livro: C# 3.0 Guia de Bolso
Livro: Desenvolvendo Information Cards e CardSpace: Do Iniciante ao Profissional
Livro: Desenvolvimento em Camadas com C# .NET
Livro: Use a Cabeça C#
Livro: LINQ Guia de Bolso
Livro: ASP.NET 2.0 Web Parts em Ação
CD/DVD: DVD de Treinamento Explorando o LINQ para SQL
CD/DVD: CD de Treinamento – Implementando AJAX em páginas ASP.NET 3.5 com o Visual Studio .NET 2008
Livro: Soa na Prática - A arte da modelagem de Sistemas Distribuídos
Livro: C# Guia de Consulta Rápida
Livro: Windows Presentation Foundation
Livro: Pro WF Windows Workflow no .NET 3
Livro: Como programar com ASP.Net e C#
CD/DVD: CD de Treinamento sobre ASP.NET 2.0 Básico
CD/DVD: CD de treinamento: Um mergulho no Controle GridView do ASP.NET 2.0
E-Book: Banco de dados com C# e Visual Studio .Net 2005 (entrega via download)
Livro: Desenvolvendo Macros no Excel
© Copyright 2001-2010 Codeline Editora, Comércio e Tecnologia Ltda. | Política de privacidade e de uso | Anuncie | Fale conosco

» Site hospedado na Porta 80 Web Hosting «
Nossos números
Dicas: 1.314
Códigos/scripts: 279
Funções de VBScript : 90
Funções JScript : 05
Livros: 1.805
Notícias: 1.942
Artigos: 2.746
Cases: 14
Oportunidades: 4.185
Publicidade

Conheça a loja do Linha de Código.

Microsoft indica Linha de Código.

Assine a Revista Mundo .NET
Portal de Vídeos .NET - os melhores vídeos .NET estão aqui
Baixe o Visual Studio 2010 Beta
Revista Codificando .Net

Siga-nos no Twitter

Linha de Código no Orkut
Fórum de discussão do portal Linha de Código
Feeds
Oportunidades
Notícias
Artigos
Artigos personalizado
       (Por assunto)
Artigos personalizado
       (Por autor)
Portal Vídeos .NET
Portal Vídeos Delphi
LC Blog
       (Onde você faz a notícia)
Promoções
Promoção Mobile (válido somente para pagamento via boleto bancário)
Promoção Mobile (válido somente para pagamento via boleto bancário)
De: R$ 239,00
Por: R$ 146,00
Promoção: Portal de Vídeos .Net + CD Novidades das Linguagens (válido somente para pagamento via boleto bancário)
De: R$ 162,00
Por: R$ 89,00
Promoção VSTS (válido somente para pagamento via boleto bancário)
De: R$ 219,00
Por: R$ 146,00
Promoção Linq To SQL (válido somente para pagamento via boleto bancário)
De: R$ 249,00
Por: R$ 156,00
Promoção ASP.Net com Banco de Dados (válido somente para pagamento via boleto bancário)
De: R$ 249,00
Por: R$ 146,00
CDs
DVD de Treinamento LINQ TO SQL e Entity Framework Avançado
DVD de Treinamento LINQ TO SQL e Entity Framework Avançado
De: R$ 83,00
Por: R$ 73,00
Curso completo de MySQL
Por: R$ 89,00
DVD de Treinamento - ISA Server 2006 - Implementação
De: R$ 83,00
Por: R$ 73,00
CD de Treinamento Adobe Photoshop CS4 Extended – 3D Arte
De: R$ 83,00
Por: R$ 53,00
DVD de Treinamento - Recursos avançados do Windows Mobile 6
De: R$ 83,00
Por: R$ 73,00
Livros
Aprendendo SQL
Aprendendo SQL
Por: R$ 83,00
Web Services SOAP em Java
Novatec
Por: R$ 42,00
Guia Mangá de Bancos de Dados
Novatec
Por: R$ 39,00
Guia Mangá de Estatística
Novatec
Por: R$ 39,00
Guia Mangá de Eletricidade
Novatec
Por: R$ 39,00
E-Books
Manual Completo de Estudos MCSE 70-270 - Instalando, Configurando e Administrando o Windows XP (506 páginas) - Entrega via download
Manual Completo de Estudos MCSE 70-270 - Instalando, Configurando e Administrando o Windows XP (506 páginas) - Entrega via download
Por: R$ 30,00
Manual de Estudos - Exame 70-291 - Windows Server 2003 (606 páginas) - entrega via download
Por: R$ 30,00
Dominando MS – Visio ® em 20 Passos - Melhores Práticas em Gestão de Projetos (entrega via download)
Por: R$ 30,00
MS-Project® 2007 - Melhores Práticas de Gestão de Projetos - Dominando MS – Project ® em 20 Passos (e-book com entrega via download)
Por: R$ 20,00
Banco de dados com C# e Visual Studio .Net 2005 (entrega via download)
Por: R$ 20,00
Os 10+ | Autores do dia
Israel Aéce
Júlio Cesar Fabris Battisti
Alfred Reinold Baudisch
Luiz Felipe de Freitas
Anderson Patricio
Ramon Durães
Robert Martim
Fernando Amaral
Eric C M Oliveira
Marcio Franco
Os 10+ | Artigos do dia
HTML Básico
HTML Avançado
SAP Business One - Implementação e Localização para o Brasil – Overview
PL/SQL - Procedures e Funções
ASP.NET 2.0 - Explorando o GridView
Tutorial de Tabelas Dinâmicas no Excel – Parte 1
PHP: Upload de imagens com segurança
Nota Fiscal Eletrônica - Geração, Assinatura e Transmissão
Criando aplicativos para o Orkut
Instalando Apache + MySQL + PHP 5 no Windows