Форум программистов, компьютерный форум CyberForum.ru

Ошибки в многопоточном вычислении средствами с++11 - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Неправильно считает http://www.cyberforum.ru/cpp-beginners/thread1307827.html
#include<iostream> #include<clocale> #include<cmath> #include<cstdlib> #include<cstring> using namespace std; double volume(double r1, double r2) { return (4./3.)*M_PI*pow(r1,3)-(4./3.)*M_PI*pow(r2,3); }
C++ Разница между перегрузкой операторов внешней или внутренней функцией Перегружаю operator* (умножаю экземпляры своего класса между собой). Как лучше перегрузить: MyClass operator*(MyClass a, MyClass b){}или MyClass MyClass::operator* (const MyClass& a){}Страуструп предпочитает внешние функции, в интернете находил сторонников внутренних, но никто не приводит каких-либо аргументов... http://www.cyberforum.ru/cpp-beginners/thread1307808.html
C++ Странности с неразрешёнными файлами include (Kubuntu, NetBeans)
Всем привет. Буквально несколько дней назад я начал осваивать C++. Мне захотелось попробовать из готовых примеров создать демон, который я ранее написал на PHP. Назначение демона - соединение раз в секунду с базой данных, проверка значений в определённых таблицах и в зависимости от них выполнение неких заложенных в логику правил. Обычно пользоваться готовыми примерами мне удавалось...
C++ Ошибка в программе
Откуда берутся эти числа? Задание (если нужно): Дан одномерный массив из 100 элементов, состоящий из случайных вещественных чисел в диапазоне от -35 до 50. Вывести в порядке не убывания (возрастания) те положительные элементы этого массива, которые меньше заданного числа Х (0<X<50). // ConsoleApplication1.cpp: определяет точку входа для консольного приложения. // #include "stdafx.h"...
C++ Странности с неразрешёнными файлами include (Kubuntu, NetBeans) http://www.cyberforum.ru/cpp-beginners/thread1307796.html
Всем привет. Буквально несколько дней назад я начал осваивать C++. Мне захотелось попробовать из готовых примеров создать демон, который я ранее написал на PHP. Назначение демона - соединение раз в секунду с базой данных, проверка значений в определённых таблицах и в зависимости от них выполнение неких заложенных в логику правил. Обычно пользоваться готовыми примерами мне удавалось...
C++ Контейнер list Добрый день! Помогите пожалуйста разобраться, никогда раньше не работал с листом. Задача следующая: В числовой последовательности вставить после каждого простого числа удвоенное среднее геометрическое всех элементов последовательности. Реализация при помощи STL. Заранее Спасибо! #include <iostream> #include <time.h> #include <stdlib.h> #include <math.h> #include <list> подробнее

Показать сообщение отдельно
DrOffset
6461 / 3835 / 886
Регистрация: 30.01.2014
Сообщений: 6,630
22.11.2014, 21:47     Ошибки в многопоточном вычислении средствами с++11
Цитата Сообщение от Satansoft Посмотреть сообщение
Алгоритм:
1. Инициализируем переменную миски сливами (100).
2. Создаем массив потоков (20)
3. Создаем поток мамы
4. 20 потоков по очереди декрементируют переменную в цикле
5. По достижению 0, она переинициализируется 100 и всё повторяется
Условие выхода, нужные задержки, вывод в консоль добавишь сам по вкусу.
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
#include <iostream>
#include <mutex>
#include <thread>
#include <condition_variable>
//#include <unistd.h>
 
std::mutex foodMutex;
std::condition_variable foodCond;
 
int plums = 100;
 
void child()
{
    while(1)
    {
        {
            std::unique_lock<std::mutex> lk(foodMutex);
            if(plums == 0) // сливы кончились
            {
                foodCond.notify_one(); // извещаем мамашу
                foodCond.wait(lk, [] { return plums > 0; }); // ждем наполнения тарелки
            }
            --plums;
            //std::cout << "plums left: " << plums << std::endl;
        }
        //usleep(500000);
    }
}
 
int main()
{
    std::thread threads[20];
 
    for(auto & a : threads)
    {
        a = std::thread(&child);
    }
    while(1)
    {
        {
            std::unique_lock<std::mutex> lk(foodMutex);
            foodCond.wait(lk, [] { return plums == 0; } ); // ждем пока сливы не кончатся
            plums = 100;
            foodCond.notify_all();
            //std::cout << "Mom added plums" << std::endl;
        }
        //usleep(1000000); 
    }
}
 
Текущее время: 19:43. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru