C# .NET Boas práticas de programação Fabiano Roman Beraldi Email:
[email protected]
Boas práticas de programação C# .NET
Este documento descreve boas práticas de programação na plataforma .NET. Nós iremos ver: • Padrões C# de nomenclatura; • Dicas para boas práticas de programação; Qual a finalidade: • Escrever códigos de qualidade e fácil manutenção; Em quais situações utilizaremos estes recursos: • No desenvolvimento de qualquer programa .NET; Nota: apesar de existirem milhares de padrões, podemos dizer que nenhum deles está errado. O importante é escolher e seguir um padrão de desenvolvimento.
A linguagem de programação C# é case sensitive, ou seja, é sensível a letras maiúsculas e minúsculas. O compilador faz distinção entre letras com “CAIXA ALTA” e “caixa normal”. Portanto é importante nos basearmos nos padrões de nomenclatura – Naming Guide C# .Net. Os estilos de nomenclaturas que foram utilizados neste documento, baseiam-se nos Capitalization Styles da Microsoft. Nota: Os termos Pascal Casing e Camel Casing serão utilizados neste documento.
Pascal Case Descrição: a primeira letra do identificador e primeira letra de cada palavra concatenada em maiúsculo. Use Pascal Case para: • Nome de classes e propriedades: public class Pessoa { public int Id {get; set;} public string Nome {get; set;} public string EnderecoResidencial {get; set;} } •
Nome de métodos:
public void RealizarVenda() { }
Camel Case Descrição: primeira letra minúscula e cada palavra concatenada em maiúscula. Use Camel Case para: • Nome de variáveis: int contagemTotal = 0; •
Parâmetros dos métodos:
private int SomarNumeros(int primeiroNumero, int segundoNumero) { int valorDaSoma = primeiroNumero + segundoNumero; return valorDaSoma; } • Use o prefixo I com Camel Case para interfaces. Ex: IEntidade;
Dicas de nomenclatura
• Dê um nome significativo para suas variáveis e evite abreviações: Correto: string nomeCompleto; DateTime dataDeNascimento; Incorreto: string nomComp; DateTime datNasc; • Não use caracteres simples para nomear suas variáveis, como por exemplo i, n, s, etc. Ao invés disto, use uma palavra como index, número, etc. Uma exceção, seria no uso de loops: for (i == 0; i < 10 ; i++) { }
Dicas de nomenclatura (cont.) • Não use underline (“_”) para variáveis locais; • Não utilize acentos ou espaços; • Variáveis booleanas deverão receber nomes que impliquem em verdadeiro ou falso: Ex.: bool existeTitulo; • Não criar nomes que podem conflitar com palavras reservadas do .NET Framework como where, string, etc. • A clareza nos nomes é essencial, isto facilitará muito uma manutenção futura no sistema; Nomenclatura para projetos do Visual Studio • Não criar itens dentro de uma Solution com o mesmo nome da Solution porque o VS não saberá quando estamos nos referindo ao rootnamespaces e poderá gerar erros;
Dicas de nomenclatura (cont.)
Nomenclatura para projetos do Visual Studio (continuação) • Os nomes de projetos devem ser criados contendo o nome da Solução mais o nome do Projeto, exemplo: Nome da solução: - PontoDeVenda Nome dos projetos: - PontoDeVenda.DAL - PontoDeVenda.Repositorio - PontoDeVenda.Webform - PontoDeVenda.TestesUnitarios
Comentários Descrição: os comentários poderão ser utilizados para identificação das funcionalidades dos métodos como também gerar documentação técnica de métodos para o sistema. • Sempre comentar os códigos gerados principalmente partes críticas ou complexas; • Os comentários devem ser no mesmo nível do código. Use o mesmo nível da endentação. Exemplo: Correto //Atribui à variável o valor da data atual DateTime dataAtual = DateTime.Now; Incorreto //Atribui à variável o valor da data atual DateTime dataAtual = DateTime.Now;
Indentação e Espaçamento
Dicas: • Use TAB para indentação ao invés de espaços; • Use uma linha em branco para separar grupos lógicos. Exemplo: Correto string DigaOla (string nome) { DateTime horaAtual = DateTime.Now; string mensagem = String.Empty; string mensagemCompleta; mensagem = “Olá” + nome; mensagemCompleta = mensagem + “, a hora atual é “ + horaAtual.ToShortTimeString(); return mensagemCompleta; }
Indentação e Espaçamento (cont.) Dicas (continuação): Incorreto string DigaOla (string nome) { DateTime horaAtual = DateTime.Now; string mensagem = String.Empty; mensagem = “Olá” + nome; string mensagemCompleta; mensagemCompleta = mensagem + “, a hora atual é “ + horaAtual.ToShortTimeString(); return mensagemCompleta; }
• Use #region para agrupar métodos ou declarações relacionados. Deste modo o código ficará mais organizado. • Mantenha as variáveis na parte superior;
Nomenclatura de Objetos UI
Ao adicionar algum objeto para alguma interface de usuário (UI) que podem ser tanto web como desktop devemos observar as nomenclaturas das seguintes tabelas: • Windows Forms, WPF
Nomenclatura de Objetos UI •
Windows Forms, WPF (continuação)
Nomenclatura de Objetos UI •
WebPages, WebParts, WebForms
Referências http:// www.devmedia.com.br/padroes-de-desenvolvimento-seguindo-boas-praticas-de-progr amacao/10751 http://devluciano.wordpress.com/2011/07/04/padres-de-nomenclaturas-naming-guide-cnet / http://pt.wikipedia.org/wiki/Case_sensitive