На главную Наши проекты:
Журнал   ·   Discuz!ML   ·   Wiki   ·   DRKB   ·   Помощь проекту
ПРАВИЛА FAQ Помощь Участники Календарь Избранное RSS
msm.ru
Обратите внимание:
1. Прежде чем начать новую тему или отправить сообщение, убедитесь, что вы не нарушаете правил форума!
2. Обязательно воспользуйтесь поиском. Возможно, Ваш вопрос уже обсуждали. Полезные ссылки приведены ниже.
3. Темы с просьбой выполнить какую-либо работу за автора в этом разделе не обсуждаются.
4. Используйте теги [ code=cpp ] ...текст программы... [ /code ] для выделения текста программы подсветкой.
5. Помните, здесь телепатов нет. Старайтесь формулировать свой вопрос максимально грамотно и чётко: Как правильно задавать вопросы
6. Запрещено отвечать в темы месячной и более давности без веских на то причин.

Полезные ссылки:
user posted image FAQ Сайта (C++) user posted image FAQ Форума user posted image Наши Исходники user posted image Поиск по Разделу user posted image MSDN Library Online (Windows Driver Kit) user posted image Google

Ваше мнение о модераторах: user posted image B.V.
Модераторы: B.V.
Страницы: (2) 1 [2]  все  ( Перейти к последнему сообщению )  
> Использование OpenMP
    Цитата tuchin @
    Потому что многопоточным программированием никогда не занимался, решил, что профессионалы (которые создали OpenMP, OpenCL, C++ AMP) лучше справятся с задачей создания многопоточного программирования, чем новичок.

    Забей на omp, работай с обычными потоками. В windows это одно удовольствие. Заодно научишься.
      Цитата Олег М @
      Забей на omp, работай с обычными потоками. В windows это одно удовольствие. Заодно научишься.

      Возникли следующие вопросы:
      1. А при обычном многопоточном программировании (без использовании специальных технологий) существуют какие-либо гарантии, что будут использоваться все ядра процессора или видеокарты?
      2. А может быть так, что при создании нескольких потоков будет использоваться только одно ядро?
      3. Как я понимаю, технологии OpenMP, OpenCL, C++ AMP гарантируют задействовании всех возможностей многоядерной аппаратуры (CPU и GPU). Другое дело, что сам реализованный алгоритм может плохо поддаваться распараллеливанию. Правильно я понимаю?
      Сообщение отредактировано: tuchin -
        Цитата tuchin @
        1. А при обычном многопоточном программировании (без использовании специальных технологий) существуют какие-либо гарантии, что будут использоваться все ядра процессора или видеокарты?
        2. А может быть так, что при создании нескольких потоков будет использоваться только одно ядро?
        3. Как я понимаю, технологии OpenMP, OpenCL, C++ AMP гарантируют задействовании всех возможностей многоядерной аппаратуры (CPU и GPU). Другое дело, что сам реализованный алгоритм может плохо поддаваться распараллеливанию. Правильно я понимаю?

        Всё будет нормально. Планированием потоков занимается операционная система, а не компилятор. Ты, конечно, можешь вмешиваться в этот процесс,но не стоит - сделаешь только хуже.
        Алгоритмы бывают разные, но в любом случае ты должен чётко представлять что ты распараллеливаешь, что у тебя блокируется и т.д.
          А какую книгу посоветуете для изучения многопоточного программирования?
            Единственное, что могу посоветовать – Джеффри Рихтер "Windows для профессионалов". Я больше ничего не читал.
            0 пользователей читают эту тему (0 гостей и 0 скрытых пользователей)
            0 пользователей:


            Рейтинг@Mail.ru
            [ Script execution time: 0,0249 ]   [ 16 queries used ]   [ Generated: 25.04.24, 04:59 GMT ]