0 / 0 / 0
Регистрация: 01.07.2014
Сообщений: 7
1

С++ 11 потоки для начинающих

01.07.2014, 12:53. Показов 3344. Ответов 13
Метки нет (Все метки)

Ранее никогда с потоками дело не имел, не знаю толком никакой теории(если можно, посоветуйте конкретные примеры для быстрого освоения). Существует задача: в одном потоке к некой общей строке что-то прибавляется, а в другом потоке мониторится длина этой строки, и при достижении длины, допустим в 500 символов строка отчищается. Вычитал, что нужен mutex(не понял толком, что это; понял, что это какой-то простейший синхронизатор), но не знаю как применить. Грубая накидка кода.
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
#include <iostream>
#include <thread>
#include <stdlib.h>
#include <cstring>
 
std::string glob = "";
 
void thread_addition()
{
    while (1)
    {
        glob += "ab";
        std::cout << "additional_thread -- " << glob << "\n";
        sleep(3);
    }
}
 
void thread_monitoring()
{
    if (glob.size() > 500)
        glob = "";
}
 
 
int main()
{
     std::thread additor(thread_addition);
     std::thread monitor(thread_monitoring);
     additor.join();
     monitor.join();
     return 0;
}
Прошу вашей помощи в доработке, в советах на будущее, в понятии философии потоков...
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
01.07.2014, 12:53
Ответы с готовыми решениями:

Что такое потоки ввода, потоки вывода?
Здарова всем! Не так давно уже прогаю на С++ и все НИКАК не могу понять, что такое потоки ввода,...

Потоки для чайников
Я в дельфи не очень шарю, но вот пришлось занятся, Цель: Управление скриптами сайта Задача:...

Потоки для службы
Всем привет! Есть небольшой опыт в создании служб, но увы он не самый удачный. Требуется сделать...

Потоки для перемножение матриц
Здравствуйте, помогите пожалуйста пояснить, как описать функцию умножения матриц под потоки. Я...

13
Неэпический
17807 / 10579 / 2042
Регистрация: 27.09.2012
Сообщений: 26,609
Записей в блоге: 1
01.07.2014, 12:55 2
Цитата Сообщение от petr_shumilov Посмотреть сообщение
если можно, посоветуйте конкретные примеры для быстрого освоения
на счет быстрого не знаю, но вот http://www.ozon.ru/context/detail/id/17636939/
0
3254 / 2056 / 351
Регистрация: 24.11.2012
Сообщений: 4,909
01.07.2014, 13:28 3
Цитата Сообщение от petr_shumilov Посмотреть сообщение
ычитал, что нужен mutex(не понял толком, что это; понял, что это какой-то простейший синхронизатор), но не знаю как применить
http://en.cppreference.com/w/cpp/thread/mutex
0
0 / 0 / 0
Регистрация: 01.07.2014
Сообщений: 7
01.07.2014, 13:34  [ТС] 4
Типичный ответ на русском форуме. Конечно я первым делом сгонял на референс, однако обычно я не читаю там теории из-за плохого знания английского, а просто беру код примеров. Я прошу, чтоб вы "разжували". Как мне доработать приведённый выше код??
0
Эксперт по математике/физикеЭксперт С++
2004 / 1335 / 379
Регистрация: 16.05.2013
Сообщений: 3,454
Записей в блоге: 6
01.07.2014, 13:38 5
Есть замечательная книга по потокам в C++11
Э. Уильямс Параллельное программирование на С++ в действии.
http://www.ozon.ru/context/detail/id/17636939/
Советую ознакомится.
В данном случае вам думаю следует смотреть не в сторону мьютексов, а по большей части condition_variable.
1
7376 / 6295 / 2859
Регистрация: 14.04.2014
Сообщений: 27,297
01.07.2014, 13:46 6
В простейшем случае так:
C++
1
2
3
4
5
mutex m;
// В каждом потоке:
m.lock();
// Здесь обращение к данным
m.unlock()
0
Эксперт по математике/физикеЭксперт С++
2004 / 1335 / 379
Регистрация: 16.05.2013
Сообщений: 3,454
Записей в блоге: 6
01.07.2014, 13:55 7
В п. 4.1.1 практически аккурат ваш пример.

Добавлено через 7 минут
Вот рабочий пример. Если это то что вы хотели?...
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
#include <iostream>
#include <thread>
#include <string>
#include <windows.h>
#include <mutex>
#include <condition_variable>
 
std::string glob = "";
std::condition_variable monitoring;
std::mutex mut;
void thread_addition()
{
    while (true)
    {
        std::lock_guard<std::mutex> lk(mut);
        glob += "ab";
        std::cout << "additional_thread -- " << glob << "\n";
        monitoring.notify_one();
        Sleep(100);
    }
}
 
void thread_monitoring()
{
    while(true) {
        std::unique_lock<std::mutex> lk(mut);
        monitoring.wait(lk, [](){ return glob.size() > 50; });
        glob = "";
    }
 
}
 
 
int main()
{
     std::thread additor(thread_addition);
     std::thread monitor(thread_monitoring);
     additor.join();
     monitor.join();
     return 0;
}
1
0 / 0 / 0
Регистрация: 01.07.2014
Сообщений: 7
01.07.2014, 14:03  [ТС] 8
Всё разобрался
0
7376 / 6295 / 2859
Регистрация: 14.04.2014
Сообщений: 27,297
01.07.2014, 14:05 9
Цикл while(true) добавь в поток, как у Ilot в примере.
0
Ilot
01.07.2014, 14:14
  #10

Не по теме:

Цитата Сообщение от petr_shumilov Посмотреть сообщение
Всё разобрался
Я тоже так хочу, а то мне для понимания потоков несколько недель потребовалось и то не думаю, что уверенно себя в них чувствую.:D

0
17110 / 9129 / 2236
Регистрация: 30.01.2014
Сообщений: 15,915
01.07.2014, 14:21 11
petr_shumilov,
Вариант с возможностью нормального выхода:
Кликните здесь для просмотра всего текста
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
#include <cstdio>
#include <thread>
#include <mutex>
#include <condition_variable>
 
int main()
{
    std::string str;
    std::mutex  m;
    std::condition_variable cond;
 
    bool done = false;
 
    std::thread producer([&]()
        {
            for (int i = 0; i < 10; ++i)
            {
                std::this_thread::sleep_for(std::chrono::seconds(1));
                std::unique_lock<std::mutex> lock(m);
 
                str += "abcdef";
                printf("Pushing to string... Length %d\n", str.length());
                cond.notify_one();
            }
 
            std::unique_lock<std::mutex> lock(m);
            done = true;
            cond.notify_one();
        }
    );
 
    std::thread consumer([&]()
        {
            while(1)
            {
                std::unique_lock<std::mutex> lock(m);
                while(!done && str.length() < 50)
                {
                    cond.wait(lock);
                }
                if(done)
                {
                    break;
                }
                str.clear();
                printf("Cleaning...\n");
            }
        }
    );
 
    producer.join();
    consumer.join();
}
0
0 / 0 / 0
Регистрация: 01.07.2014
Сообщений: 7
01.07.2014, 14:23  [ТС] 12
Что-то у меня не работает, как слепой котёнок я в потоках. Я хочу добиться результата при котором будет вот такой вывод:

additional_thread -- ab
additional_thread -- abab
additional_thread -- ababab
additional_thread -- abababab
additional_thread -- ababababab
additional_thread -- ab
additional_thread -- abab
additional_thread -- ababab
additional_thread -- abababab
additional_thread -- ababababab
при условии, что количество символов, при котором строка отчищается 10
0
17110 / 9129 / 2236
Регистрация: 30.01.2014
Сообщений: 15,915
01.07.2014, 14:28 13
petr_shumilov,
Кликните здесь для просмотра всего текста
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
#include <cstdio>
#include <thread>
#include <mutex>
#include <condition_variable>
 
int main()
{
    std::string str;
    std::mutex  m;
    std::condition_variable cond;
 
    bool done = false;
 
    std::thread producer([&]()
        {
            for (int i = 0; i < 30; ++i)
            {
                std::this_thread::sleep_for(std::chrono::seconds(1));
                std::unique_lock<std::mutex> lock(m);
 
                str += "ab";
                printf("%s\n", str.c_str());
                cond.notify_one();
            }
 
            std::unique_lock<std::mutex> lock(m);
            done = true;
            cond.notify_one();
        }
    );
 
    std::thread consumer([&]()
        {
            while(1)
            {
                std::unique_lock<std::mutex> lock(m);
                while(!done && str.length() < 10)
                {
                    cond.wait(lock);
                }
                if(done)
                {
                    break;
                }
                str.clear();
            }
        }
    );
 
    producer.join();
    consumer.join();
}
1
ну и долго меня небыло...
61 / 57 / 8
Регистрация: 24.03.2013
Сообщений: 173
01.07.2014, 15:48 14
а как же хабра? http://habrahabr.ru/post/182610/
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
01.07.2014, 15:48
Помогаю со студенческими работами здесь

Потоки для динамических объктов
Здравствуйте! Я имею некий динамический объект - словарь или лист. И мне нужно организовать...

Потоки, синхронизация для работы с формой
Доброго времени суток. Собственно сабж. На форме есть text box - tbStatus в которую пытаюсь писать...

Сделать потоки для данной программы
Здравствуйте! Помогите пожалуйста решить задачку. 1) Итерацию, процесс вывода сделать в отдельном...

Потоки и асинхронность для бота в телеграмме
Здравствуйте! В двух словах, что делаю: пишу бота, играющего в города для telegram. Но вот...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2023, CyberForum.ru