Ускорение в 3,7 раза после удаления Sleep() в WebKit

в 8:26, , рубрики: safari, sleep, webkit, сборщик мусора, Совершенный код, спинлок, метки: , , , ,

Джофф Гарен (Geoff Garen) из компании Apple обнаружил вызов Sleep() в спинлоке функции TCMalloc сборщика мусора WebKit.

 -#if OS(WINDOWS)
-    Sleep(2);
-#else
-    struct timespec tm;
-    tm.tv_sec = 0;
-    tm.tv_nsec = 2000001;
-    nanosleep(&tm, NULL);
-#endif

После удаления Sleep производительность сборщика в определённых условиях выросла в 3,7 раза. Это наглядный пример, как одна маленькая оптимизация способна и уменьшить размер кода, и одновременно в несколько раз повысить производительность.

На HN по этому поводу развернулась дискуссия: мол, зачем там вообще был вызов Sleep(), если его использование в спинлоках считается дурным тоном.

В итоге обнаружился тот разработчик, который и внедрил вызов Sleep в WebKit. Он объяснил, что изначально эта кастомная функция для динамического выделения памяти TCMalloc разрабатывалась для серверов, и спинлок такого вида был там по определённой причине, но эта причина, наверное, не так актуальна для WebKit как браузерного движка.

Сам Джофф Гарен высказался в том же смысле, но в более наглядной форме:

Ускорение в 3,7 раза после удаления Sleep() в WebKit

Изменение в коде WebKit сделано в мае 2012 года, так что последний Safari наверняка работает уже на оптимизированной версии.

Автор: alizar

* - обязательные к заполнению поля


https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js