Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
MastAKK
148 / 139 / 18
Регистрация: 13.10.2012
Сообщений: 592
1

Как работать с переменной в нескольких потоках?

16.08.2014, 23:32. Просмотров 347. Ответов 6
Метки нет (Все метки)

Собственно, вся суть в названии темы. Подскажите, как я могу изменить переменную в дочерних потоках так, чтобы она изменялась и в основном?
0
QA
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.08.2014, 23:32
Ответы с готовыми решениями:

Работа с std::map одновременно в нескольких потоках
У меня есть мапа: std::map<std::string, bool> map_password; (ключ - предполагаемый пароль, значение...

В нескольких потоках указатель указывает на одну и ту же область памяти
Доброго времени суток форумчане. Столкнулся со следующей проблемой: при выделении памяти под...

Создание WinApi функции для нахождения максимального элемента массива в нескольких потоках
Задача состоит в следующем: ножно написать программу, которая будет находить максимальное значение...

Как работать с переменной типа char?
Не понимаю переменную char и как с ней работать.

Использование переменной в нескольких потоках
Пишу многопоточный сервер на C#. Всю информацию о клиентах храню в списках (их несколько). Потоков...

6
DrOffset
11409 / 6155 / 1502
Регистрация: 30.01.2014
Сообщений: 10,025
17.08.2014, 00:41 2
Хабр конечно не самый лучший источник информации, но представление определенное получишь. В любом случае проще прочитать там, чем сейчас тут целую статью писать
1
MastAKK
148 / 139 / 18
Регистрация: 13.10.2012
Сообщений: 592
17.08.2014, 00:45  [ТС] 3
DrOffset, ну что же, действительно, придётся почитать хабр. Может и тонкости какие узнаю.
Благодарб за ссылку
0
Andrej
И целого heap'а мало
95 / 56 / 17
Регистрация: 31.07.2014
Сообщений: 291
17.08.2014, 00:45 4
Bash
1
clang++ --std=c++11 queue.cpp -o queue -lpthread
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
#include <mutex>
#include <iostream>
#include <thread>
#include <queue>
#include <condition_variable>
 
template <typename Event>
struct ThreadSafeQueue {
public: /* methods: */
        Event /* Called by the consumer. */
        getEvent()
        {
                std::unique_lock<std::mutex> lock(mutex);
                while (events.empty()) {
                        condition_variable.wait(lock);
                }
                auto tmp = events.front();
                events.pop();
                return tmp;
        };
 
        void /* Used by the producer. */
        setEvent(Event event)
        {
                std::lock_guard<std::mutex> lock(mutex);
                events.push(event);
                condition_variable.notify_one();
        };
 
private: /* fields: */
        std::queue<Event> events;
        std::mutex mutex;
        std::condition_variable condition_variable;
};
 
struct Event {
        char c;
};
 
ThreadSafeQueue<Event> queue;
 
void
getChar()
{
        char tmp;
        while (std::cin >> tmp)
        {
                Event event {tmp};
                queue.setEvent(event);
        }
};
 
void
print()
{
        while (true)
        {
                std::cout << queue.getEvent().c << std::endl;
        }
};
 
int
main(int argc, char** argv)
{
        std::thread printer {print};
        printer.detach();
        getChar();
};
На пример, наипростейшая потокобезопастная очередь. Защищена мьютексом, который лочится в RAII стиле, то бишь создаётся переменная std::lock_guard<std::mutex> lock(mutex) она в конструкторе делает lock(), когда теряется область, в деструкторе вызывается unlock(). Вообще, всё это ооп-шный сахар. Помутузь posix threads, или виндапотоки, а всё вышеприведённое - ни что иное как обёртка над системными тредами. Можешь даже сам попробовать потом обернуть нативные потоки согласно плюснотому стандарту.
1
MastAKK
148 / 139 / 18
Регистрация: 13.10.2012
Сообщений: 592
17.08.2014, 01:05  [ТС] 5
Andrej, проблема в том, что хотелось бы без блокировки потока. То бишь, запустить несколько отдельных потоков, работающих параллельно.
Или mutex позволяет одновременную работу нескольких потоков?
0
Andrej
И целого heap'а мало
95 / 56 / 17
Регистрация: 31.07.2014
Сообщений: 291
17.08.2014, 01:17 6
MastAKK, да, позволяет. Идея этой штуки как раз в том, чтобы был один потребитель и N производителей событий.
Здесь только потребитель висит на ожидании.
std::thread::detach метод делает поток независимым. А вот std::thread::join ждёт окончания исполнения потока.
0
Убежденный
Ушел с форума
Эксперт С++
16271 / 7337 / 1183
Регистрация: 02.05.2013
Сообщений: 11,637
Записей в блоге: 1
Завершенные тесты: 1
17.08.2014, 10:21 7
Цитата Сообщение от MastAKK Посмотреть сообщение
Подскажите, как я могу изменить переменную в дочерних потоках так, чтобы она изменялась и в основном?
Для начала почитать про std::atomic/Boost.atomic.

http://ru.cppreference.com/w/cpp/atomic/atomic
http://www.boost.org/doc/libs/1_55_0/doc/html/atomic.html
0
17.08.2014, 10:21
Answers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
17.08.2014, 10:21

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

Как выполнить подцикл for в (отдельных) нескольких потоках параллельно?
Есть код с двумя циклами for: for (int a = 0; a != numb1; a++) { //тут весь код для запуска и...

"Недопустимая операция в нескольких потоках" как исправить данный недуг?
Здравствуйте, помогите пожалуйста исправить ошибку, вроде сделал с горем пополам вывод времени до...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2020, vBulletin Solutions, Inc.