一些写代码注意性能的地方

以下全是网络找到的。


拼接字符串时,值类型一定要加上ToString()

比如用:string a = "aa" + 123.ToString();

而不是用string a = "aa" + 123

字符串比较或查找:str.IndexOf("abc"),请加上StringComparison.Ordinal

比如要使用:str.IndexOf("abc", StringComparison.Ordinal),参数如果要忽略大小写,请使用StringComparison.OrdinalIgnoreCase。

而不是直接:str.IndexOf("abc"),它相当于str.IndexOf("abc", StringComparison.CurrentCulture)。

StringComparison.CurrentCulture:使用区域敏感排序规则和当前区域比较字符串
StringComparison.Ordinal:使用序号排序规则比较字符串

HashTable、Dictionary、SortedList、SortedDictionary等字典使用

a、使用字典的TryGetValue方法,如:
Dictionary<string, string> abc;
string a;
if(!abc.TryGetValue(key, out a)){
//key不存在
}else{
}
而不要用下面的代码,因为下面的代码重复查找了2次key:
if(!abc.ContainKeys(key))
{
//key不存在
}else{
a = abc[key];
}
b、删除字典的key时,直接使用Remove方法,不要事先判断,比如:
Dictionary<string, string> abc;
if(abc.Remove(key)){// 没必要先判断ContainKeys,重复查找,浪费性能
//key存在,且移除成功
}else{
//key不存在,或移除失败
}
c、插入元素时,直接使用this[key] = value,如:
abc[key] = value;// 注意需求,如果允许覆盖才可以

而不需要:if(!abc.ContainsKey(key))abc.Add(key, value);
反编译代码,可以看到Add和this[]是调用同一个方法的


你可能感兴趣的:(性能)