bomzzz

Platinum Member | Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору надо было профиль сохранить. программа простенькая ее бы усложнить. HyperThreading http://ru.wikipedia.org/wiki/Hyper-threading Цитата: В процессорах с использованием этой технологии каждый физический процессор может хранить состояние сразу двух потоков, что для операционной системы выглядит как наличие двух логических процессоров (англ. Logical processor). Физически у каждого из логических процессоров есть свой набор регистров и контроллер прерываний (APIC), а остальные элементы процессора являются общими. Когда при исполнении потока одним из логических процессоров возникает пауза (в результате кэш-промаха, ошибки предсказания ветвлений, ожидания результата предыдущей инструкции), то управление передаётся потоку в другом логическом процессоре. Таким образом, пока один процесс ждёт, например, данные из памяти, вычислительные ресурсы физического процессора используются для обработки другого процесса Были представлены следующие преимущества Hyper-threading: улучшенная поддержка многопоточного кода, позволяющая запускать потоки одновременно; улучшенная реакция и время отклика; увеличенное количество пользователей, которое может поддерживать сервер. По словам Intel, первая реализация потребовала всего 5-процентного увеличения площади кристалла, но позволяла увеличить производительность на 15—30 %. Intel утверждает, что прибавка к скорости составляет 30 % по сравнению с идентичными процессорами Pentium 4 без технологии «Simultaneous multithreading». Однако прибавка к производительности изменяется от приложения к приложению: некоторые программы вообще несколько замедляются при включённой технологии Hyper-threading. Это, в первую очередь, связано с «системой повторения» (англ. replay) процессоров Pentium 4, занимающей необходимые вычислительные ресурсы, отчего и начинают «голодать» другие потоки | никто не подскажет - ядра не физические а логические, есть ли смысл разносить процессы по виртуальным ядрам? не очевидно Добавлено: вот если упростить до бассейна с двумя трубами. например у нас есть водоем и мы качаем из него воду. 1 есть два насоса которые качают воду по одной трубе и могут работать только по очереди, что дает выигрыш если один насос сломается то пока он чинится качает другой... 2 есть два паралельных насоса которые качают каждый по своей трубе - в этом случае разнос процессов по ядрам логичен, конечно если само приложение уже не оптимизировано под два ядра | Всего записей: 13343 | Зарегистр. 13-01-2008 | Отправлено: 20:56 28-07-2013 | Исправлено: bomzzz, 21:06 28-07-2013 |
|