奇怪的分支性能
2022-09-02 04:45:12
我的基准测试的结果表明,当分支具有15%(或85%)%的概率而不是50%时,性能最差。
有什么解释吗?
代码太长,但相关部分在这里:
private int diff(char c) {
return TABLE[(145538857 * c) >>> 27] - c;
}
@Benchmark int timeBranching(int reps) {
int result = 0;
while (reps-->0) {
for (final char c : queries) {
if (diff(c) == 0) {
++result;
}
}
}
return result;
}
它计算给定字符串中BREAKING_WHITESPACE个字符的数量。结果显示,当分支概率达到约 0.20 时,时间突然下降(性能提高)。
有关下降的更多详细信息。改变种子显示更多奇怪的事情正在发生。请注意,表示最小值和最大值的黑线非常短,除非靠近悬崖。