Я думаю, это потому, что вы не ожидаете разрешения асинхронного запроса.
Да, они могут. В ядре Linux они определены как
#define likely(x) __builtin_expect(!!(x), 1)
#define unlikely(x) __builtin_expect(!!(x), 0)
Макросы __builtin_expect являются специфическими макросами GCC, которые используют предсказание ветвления; они сообщают процессору, может ли условие быть истинным, чтобы процессор мог предварительно выбирать инструкции на правильной «стороне» ветви.
Вы должны заключить определения в ifdef, чтобы обеспечить компиляцию на других компиляторах:
#ifdef __GNUC__
#define likely(x) __builtin_expect(!!(x), 1)
#define unlikely(x) __builtin_expect(!!(x), 0)
#else
#define likely(x) (x)
#define unlikely(x) (x)
#endif
Это определенно даст вам оптимизацию, если вы будете использовать его для правильных предсказаний ветвления.
Посмотрите Что каждый программист должен знать о памяти в разделе «6.2.2 Оптимизация доступа к кэшу инструкций уровня 1» - здесь есть раздел именно об этом.
Макросы вероятных () и маловероятных () - это красивые названия, определенные в заголовках ядра для чего-то, что является реальной функцией gcc