O uso de string.IsNullOrEmpty(string)
ao verificar uma string é considerado uma má prática quando existe string.IsNullOrWhiteSpace(string)
no .NET 4.0 e superior?
A melhor prática é selecionar a mais apropriada.
O .NET Framework 4.0 Beta 2 possui um novo método IsNullOrWhiteSpace () para seqüências de caracteres que generaliza o método IsNullOrEmpty () para incluir também outro espaço em branco, além da seqüência vazia.
O termo "espaço em branco" inclui todos os caracteres que não são visíveis na tela. Por exemplo, espaço, quebra de linha, tabulação e sequência vazia são caracteres de espaço em branco * .
Referência: Aqui
Para desempenho, IsNullOrWhiteSpace não é ideal, mas é bom. As chamadas de método resultarão em uma pequena penalidade de desempenho. Além disso, o próprio método IsWhiteSpace possui alguns indiretos que podem ser removidos se você não estiver usando dados Unicode. Como sempre, a otimização prematura pode ser ruim, mas também é divertida.
Referência: Aqui
Verifique o código-fonte (Fonte de Referência .NET Framework 4.6.2)
[Pure]
public static bool IsNullOrEmpty(String value) {
return (value == null || value.Length == 0);
}
[Pure]
public static bool IsNullOrWhiteSpace(String value) {
if (value == null) return true;
for(int i = 0; i < value.Length; i++) {
if(!Char.IsWhiteSpace(value[i])) return false;
}
return true;
}
Exemplos
string nullString = null;
string emptyString = "";
string whitespaceString = " ";
string nonEmptyString = "abc123";
bool result;
result = String.IsNullOrEmpty(nullString); // true
result = String.IsNullOrEmpty(emptyString); // true
result = String.IsNullOrEmpty(whitespaceString); // false
result = String.IsNullOrEmpty(nonEmptyString); // false
result = String.IsNullOrWhiteSpace(nullString); // true
result = String.IsNullOrWhiteSpace(emptyString); // true
result = String.IsNullOrWhiteSpace(whitespaceString); // true
result = String.IsNullOrWhiteSpace(nonEmptyString); // false
return String.IsNullOrEmpty(value) || value.Trim().Length == 0;
que envolve uma nova alocação de string e duas verificações separadas. Provavelmente dentro de IsNullOrWhitespace, isso é feito através de uma única passagem, sem alocações, verificando se cada caractere na cadeia de caracteres é o espaço em branco, portanto, um desempenho superior. O que confunde você realmente?IsNullOrWhitespace()
corresponderia a uma string vazia. EssencialmenteIsNullOrEmpty()
corresponde a um subconjunto deIsNullOrWhitespace()
.As diferenças na prática:
fonte
São funções diferentes. Você deve decidir para sua situação o que precisa.
Não considero usar nenhum deles como uma má prática. Na maioria das vezes
IsNullOrEmpty()
é suficiente. Mas você tem a escolha :)fonte
Contains
. Se você deseja garantir que o nome de usuário não possa consistir apenas em espaços -IsNullOrWhiteSpace
está ok.IsNullOrEmpty
garante apenas que o nome de usuário tenha sido inserido de alguma forma.Aqui está a implementação real dos dois métodos (descompilada usando dotPeek)
fonte
IsNullOrWhiteSpace
é verdadestring.Empty
! Isso é um bônus :)Diz que tudo
IsNullOrEmpty()
não inclui espaçamento em branco, enquantoIsNullOrWhiteSpace()
inclui!IsNullOrEmpty()
Se a string é:-Null
-Empty
IsNullOrWhiteSpace()
Se a string é:-Null
-Empty
espaços -Contém Branca Somente
fonte
Verifique isso com IsNullOrEmpty e IsNullOrwhiteSpace
Você verá que IsNullOrWhiteSpace é muito mais lento: /
fonte
string.IsNullOrEmpty (str) - se você deseja verificar se o valor da string foi fornecido
string.IsNullOrWhiteSpace (str) - basicamente, esse já é um tipo de implementação de lógica de negócios (ou seja, por que "" é ruim, mas algo como "~~" é bom).
Meu conselho - não misture lógica de negócios com verificações técnicas. Portanto, por exemplo, string.IsNullOrEmpty é o melhor a ser usado no início dos métodos para verificar seus parâmetros de entrada.
fonte
Que tal isso para pegar tudo ...
Isso cortará todos os espaços, se houver, evitando a penalidade de desempenho de IsWhiteSpace, que permitirá que a sequência atenda à condição "vazia" se não for nula.
Eu também acho que isso é mais claro e geralmente é uma boa prática cortar seqüências de qualquer maneira, especialmente se você as estiver colocando em um banco de dados ou algo assim.
fonte
No padrão .Net 2.0:
fonte