Модераторы: Daevaorn
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Является ли этот код потокобезопасным? 
:(
    Опции темы
W4FhLF
Дата 22.1.2013, 22:19 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


found myself
****


Профиль
Группа: Участник Клуба
Сообщений: 2831
Регистрация: 2.12.2006

Репутация: 20
Всего: 121



Привет!

Собственно упрощённый код:

Код

std::vector<double> vals(nvals);
long idx = 0;

#pragma omp parallel for
    for(int i = 0; i <= nx; ++i)
    {
        for(int j = 0; j <= ny; ++j)
        {
            double v;
            ...
            InterlockedIncrement(&idx);
            vals[idx - 1] = v;
        }
    }


Если нет, то почему? 
Если да, то почему-то результаты зависят от кол-ва потоков...

Это сообщение отредактировал(а) W4FhLF - 22.1.2013, 22:39


--------------------
"Бог умер" © Ницше
"Ницше умер" © Бог
PM ICQ   Вверх
volatile
Дата 22.1.2013, 23:30 (ссылка) |    (голосов:3) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2107
Регистрация: 7.1.2011

Репутация: 37
Всего: 85



Цитата(W4FhLF @  22.1.2013,  22:19 Найти цитируемый пост)
Если нет, то почему? 

Хотя бы потому, что
Цитата(W4FhLF @  22.1.2013,  22:19 Найти цитируемый пост)
std::vector<double> vals(nvals);
long idx = 0;
#pragma omp parallel for
    for(int i = 0; i <= nx; ++i)
    {
        for(int j = 0; j <= ny; ++j)
        {
            double v;
            ...
            InterlockedIncrement(&idx);
            //---------------------------- Вот здесь idx может изменить другой поток.
            vals[idx - 1] = v;
        }
    }


Уж как минимум нужно так:
Код

            long t = InterlockedIncrement(&idx);
            vals[t - 1] = v;


что конечно еще не гарантирует потокобезопасность. сам std::vector не потокобезопасен.
если в потоках происходит изменение размера вектора, то вообще работать не будет.
и еще много других причин....
нужно смотреть весь код.

PM MAIL   Вверх
W4FhLF
Дата 23.1.2013, 20:26 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


found myself
****


Профиль
Группа: Участник Клуба
Сообщений: 2831
Регистрация: 2.12.2006

Репутация: 20
Всего: 121



Цитата(volatile @  22.1.2013,  23:30 Найти цитируемый пост)
Уж как минимум нужно так:


Вот это кажется в точку.

Цитата(volatile @  22.1.2013,  23:30 Найти цитируемый пост)
что конечно еще не гарантирует потокобезопасность. сам std::vector не потокобезопасен.
если в потоках происходит изменение размера вектора, то вообще работать не будет.
и еще много других причин....


Я забыл упомянуть, что размер вектора не меняется и каждый элемент адресуется только единожды. 


--------------------
"Бог умер" © Ницше
"Ницше умер" © Бог
PM ICQ   Вверх
volatile
Дата 23.1.2013, 23:14 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2107
Регистрация: 7.1.2011

Репутация: 37
Всего: 85



Цитата(W4FhLF @  23.1.2013,  20:26 Найти цитируемый пост)
размер вектора не меняется и каждый элемент адресуется только единожды

В таком случае все должно быть норм.

Это сообщение отредактировал(а) volatile - 23.1.2013, 23:48
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С++:Общие вопросы"
Earnest Daevaorn

Добро пожаловать!

  • Черновик стандарта C++ (за октябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика(4.4мб).
  • Черновик стандарта C (за сентябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика (3.4мб).
  • Прежде чем задать вопрос, прочтите это и/или это!
  • Здесь хранится весь мировой запас ссылок на документы, связанные с C++ :)
  • Не брезгуйте пользоваться тегами [code=cpp][/code].
  • Пожалуйста, не просите написать за вас программы в этом разделе - для этого существует "Центр Помощи".
  • C++ FAQ

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Earnest Daevaorn

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.1228 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.