Маловероятно, что многоядерные переключатели контекста будут негативно влиять на производительность приложений.
Любое переключение контекста влечет за собой прямые затраты ~ 1-4 микросекунды для сохранения / восстановления состояния потока, а также косвенные затраты на разогрев кеша. Косвенная стоимость зависит от многих факторов, таких как локальность данных и схемы доступа, и варьируется в широких пределах: от сотен наносекунд, практически ничего не добавляя к общей стоимости переключения контекста, до сотен микросекунд, увеличивая общую стоимость на два порядка.
Хотя вполне разумно ожидать, что разогрев кеша займет больше времени для многоядерного переключения контекста (если новое ядро не разделяет кеши со старым), планирование потока на том же ядре все равно потребует Разогрев кеша, поскольку некоторые или все данные потока будут вытеснены из кеша другими потоками, выполняемыми на этом промежуточном ядре.
В любом случае общая стоимость переключения контекста все равно будет незаметна по сравнению с ~ 30-120 миллисекундами кванта выполнения потока (время между переключениями контекста).
Только в патологических случаях, т. Е. Когда поток работает в течение длительного периода времени с одним и тем же набором данных, который точно вписывается в кэш общего доступа, переключение контекста между ядрами может оказывать заметное влияние на производительность. В большинстве случаев они не будут узким местом.
В качестве примечания, вопреки совету Л.Бушкина, BeginThreadAffinity
не поможет вам в привязке к процессору: он только привязывает поток .NET к конкретному потоку ОС, не к конкретному ядру.
Полезные ссылки:
[1] Использование параллелизма для масштабируемости
[2] Количественная оценка стоимости переключения контекста
[3] Сколько времени занимает переключение контекста?