Một số bài kiểm tra hiệu suất (tốc độ) tóm tắt các tùy chọn khác nhau, không phải là nó thực sự quan trọng #microoptimization (sử dụng tiện ích mở rộng linqpad )
Tùy chọn
void Main()
{
object objValue = null;
test(objValue);
string strValue = null;
test(strValue);
}
// Define other methods and classes here
void test(string value) {
new Perf<string> {
{ "coallesce", n => (value ?? string.Empty).ToString() },
{ "nullcheck", n => value == null ? string.Empty : value.ToString() },
{ "str.Format", n => string.Format("{0}", value) },
{ "str.Concat", n => string.Concat(value) },
{ "string +", n => "" + value },
{ "Convert", n => Convert.ToString(value) },
}.Vs();
}
void test(object value) {
new Perf<string> {
{ "coallesce", n => (value ?? string.Empty).ToString() },
{ "nullcheck", n => value == null ? string.Empty : value.ToString() },
{ "str.Format", n => string.Format("{0}", value) },
{ "str.Concat", n => string.Concat(value) },
{ "string +", n => "" + value },
{ "Convert", n => Convert.ToString(value) },
}.Vs();
}
Có thể quan trọng là chỉ ra rằng Convert.ToString(...)
sẽ giữ lại một chuỗi null.
Các kết quả
Vật
- nullcheck 1,00x 1221 tích tắc trôi qua (0,1221 ms) [trong 10K đại diện, 1,221E-05 ms mỗi]
- coallesce 1,14x 1387 tích tắc (0,1387 ms) [trong 10K đại diện, 1,387E-05 ms mỗi]
- chuỗi + 1,16x 1415 tích tắc đã trôi qua (0,1415 ms) [trong 10K đại diện, 1,415E-05 ms mỗi]
- str.Concat 1,16x 1420 tích tắc (0,142 mili giây) [trong 10K đại diện, 1,42E-05 mili giây mỗi]
- Chuyển đổi 1,58x 1931 tích đã trôi qua (0,1931 ms) [trong 10K đại diện, 1,931E-05 ms mỗi]
- str.Format 5,45x 6655 tích tắc trôi qua (0,6655 ms) [trong 10K đại diện, 6,655E-05 ms mỗi]
Chuỗi
- nullcheck 1,00x 1190 lần tích tắc (0,119 ms) [trong 10K đại diện, 1,19E-05 ms mỗi]
- Chuyển đổi 1,01x 1200 tích tắc trôi qua (0,12 mili giây) [trong 10K đại diện, 1,2E-05 mili giây mỗi]
- chuỗi + 1,04x 1239 tích tắc trôi qua (0,1239 ms) [trong 10K đại diện, 1,239E-05 ms mỗi]
- coallesce 1,20x 1423 tích tắc (0,1423 ms) [trong 10K đại diện, 1,423E-05 ms mỗi]
- str.Concat 4,57x 5444 tích tắc trôi qua (0,5444 mili giây) [trong 10K đại diện, 5,444E-05 mili giây mỗi]
- str.Format 5,67x 6750 tích tắc trôi qua (0,675 ms) [trong 10K reps, 6,75E-05 ms mỗi]