原先使用 CACurrentMediaTime() 進(jìn)行基準(zhǔn)測(cè)試峦剔,因?yàn)槠涫褂玫氖窍到y(tǒng)內(nèi)建時(shí)鐘浮入。不同于 NSDate 或 CFAbsoluteTimeGetCurrent() 使用的是時(shí)間偏移量。顯然內(nèi)建時(shí)鐘會(huì)更加準(zhǔn)確一些羊异,不受外部影響。最近又學(xué)習(xí)了一種使用 GCD 的方式彤断,代碼如下:
//iterations 為迭代測(cè)試次數(shù)野舶,獲得多個(gè)樣本取平均值來(lái)代表平均運(yùn)行時(shí)間,Mattt 推薦一般情況下取 10^5 ~ 10^8宰衙。
uint64_t dispatch_benchmark(size_t count, void (^block)(void));
uint64_t n = dispatch_benchmark(10000, ^{
@autoreleasepool {
NSString *str = @"forkpanda";
NSMutableArray *array = @[].mutableCopy;
for (int i = 0; i < 10000; i++)
{
[array addObject:str];
}
}
});
NSLog(@"[D] <%@|%@:%d> The average runtime for operation is %llu ns.",
NSStringFromClass([self class]), NSStringFromSelector(_cmd), __LINE__, n);
懶一點(diǎn)直接 copy 下面的宏就可以使用了:
#define PDMeasure(__t, __x) \
if (!DEBUG) { ^ __x(); return; \
} else { \
uint64_t dispatch_benchmark(size_t count, void (^)(void)); \
uint64_t n = dispatch_benchmark(10000, ^{ @autoreleasepool {{ ^ __x(); }} }); \
NSLog(@"[P] <%@|%@> The average runtime for operation is %llu ns.", NSStringFromClass([self class]), __t, n); \
}
使用方式:
PDMeasure(@"array", {
NSString *str = @"forkpanda";
NSMutableArray *array = @[].mutableCopy;
for (int i = 0; i < 10000; i++)
{
[array addObject:str];
}
})
這個(gè)宏處理了平道,如果是某個(gè)坑貨把開(kāi)發(fā)代碼 Release 的話,起碼能保證這個(gè)代碼是可以跑得過(guò)的供炼,如果是 Debug 模式下一屋,則進(jìn)行性能平均值測(cè)量窘疮,這個(gè)計(jì)算是會(huì)運(yùn)行 10000 遍。我只是懶得寫(xiě) Demo冀墨,實(shí)際項(xiàng)目中闸衫,還是自己寫(xiě)一個(gè)工具類比較靠譜。
ps. 性能檢查是為了繼續(xù)提出問(wèn)題诽嘉,而不是武斷的認(rèn)為哪種方法好蔚出。