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

Потоки и запоминание итераторов - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Постройте графики функций и найдите точки их пересечения. http://www.cyberforum.ru/cpp-beginners/thread517589.html
Помогите решить на C++: Постройте графики функций и найдите точки их пересечения. y=tgx, y=1;
C++ Используя программу вычисления транспонированной матрицы S^T Помогите решить задачу на С++: Используя программу вычисления транспонированной матрицы S^T, найдите для данных матриц A, B, C размерностью 3x3 значение выражения (A+B)^T-(A+C)^T+(B+C)^T. Заранее благодарен! http://www.cyberforum.ru/cpp-beginners/thread517586.html
C++ Пары в одномерном массиве
Составить программу, которая отыскивает среди пар элементов одномерного массива М те, разность между элементами которых есть величина наибольшая для данного массива. Т.е. нужно сначала найти максимум, а затем через условие проверить, если разность=максимуму, то это пара? так? Например: if (A-A=max) max=max+1 Но мне нужно что бы пары отыскивались по всему массиву, а не только со следующим...
Даны координаты двух C++
Даны координаты двух противоположных вершин прямоугольника: (x1, y1), (x2, y2). Стороны прямоугольника параллельны осям координат. Найти периметр и площадь данного прямоугольника. #include <iostream> #include<math.h> using namespace std; int main() { double x1,y1,x2,y2,P,A,sum;
C++ Параллельное вычисление факториала http://www.cyberforum.ru/cpp-beginners/thread517574.html
Необходимо реализовать последовательный и параллельный алгоритм вычисления факториала N!. Есть только последовательный расчёт. Если кто может распараллелить помогите пожалуйста. #include <stdio.h> #include <iostream> #include <sstream> #include <vector> #define base 1000000000 void writelong(std::vector<int> vec){ printf ("%d", vec.empty() ? 0 : vec.back()); for (int...
C++ размер матрицы #include <iostream> #include <vector> #include <stack> using namespace std; typedef vector<int > T_vec; typedef vector<T_vec> T_mtr; enum {EMPTY, POINT, NOTBOARD}; подробнее

Показать сообщение отдельно
IcyWind
8 / 8 / 2
Регистрация: 19.09.2011
Сообщений: 268
13.03.2012, 01:21     Потоки и запоминание итераторов
Жду помощи...
хочу, чтобы 2 потока запоминали итераторы, чтобы потом можно было свапнуть разыменованные иттераторы...но проблема с синхронизацией.
Как вызывать события? как они должны выглядеть...и..есть ли смысл заморачиваться с этим?
Код получается примерно такой:
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
#include "stdafx.h"
#include <Windows.h>
#include <vector>
#include <iostream>
#include <algorithm>
using namespace std;
 
static vector<int>::iterator it1;
static vector<int>::iterator it2;
 
template <typename T>
T average(T it1, T it2, T it3)
{
    if (*it1 <= *it2)
    {
        if (*it3 <= *it1)
            return it1;
        if (*it3 >= *it2)
            return it2;
        return it3;
    }
    if (*it3 <= *it2)
        return it2;
    if (*it3 >= *it1)
        return it1;
    return it3;
}
 
template <typename T>
struct para
{
    T begin,end;
    int num;
    para (T b, T e, int n)
    {
        begin = b;
        end = e;
        num = n;
    }
};
 
typedef para<vector<int>::iterator> PARAMS;
 
 
DWORD WINAPI func1(PVOID param)
{
    PARAMS* p = static_cast< PARAMS * > (param);
    int a = p->num;
    while(p->begin != p->end)
    {
        if(*p->begin >= a)
        {
            it1 = p->begin;
            //создать 1-ое событие
            //ждать 3 событие
        }
        ++p->begin;
    }
 
    return 0;
}
 
DWORD WINAPI func2(PVOID param)
{
    PARAMS* p = static_cast< PARAMS * > (param);
    int a = p->num;
    while(p->begin != p->end)
    {
        if(*p->begin <= a)
        {
            it1 = p->begin;
            //создать 2-ое событие
            //ждать 3 событие
        }
    }
    return 0;
}
 
 
int _tmain(int argc, _TCHAR* argv[])
{
 
 
    vector<int> b;
    for(int i = 0; i< 10; ++i)
        b.push_back(rand());
    /*for(unsigned int i = 0; i<b.size(); ++i)
        cout<<b[i]<<"  ";
    cout<<'\n';*/
 
    auto p_ave = b.begin();
    advance(p_ave,b.size()/2);
    
    /*cout<< *p_ave;
    cout<<'\n';*/
    swap(*p_ave, *average(b.begin(),--b.end(),p_ave));
    /*cout<<'\n';
    for(unsigned int i = 0; i<b.size(); ++i)
        cout<<b[i]<<"  ";*/
    
    
    
    
    
    
    
    
    
    /*HANDLE potok[2];
    potok[0] = CreateThread(NULL, 0, func, &p1, 0, NULL);
    potok[1] = CreateThread(NULL, 0, func, &p2, 0, NULL);
    WaitForMultipleObjects(2, potok, FALSE, INFINITE);
    */
    PARAMS p1(b.begin(),p_ave,*p_ave);
    PARAMS p2(p_ave, b.end(), *p_ave);
    
    
    HANDLE potok[2];
    potok[0] = CreateThread(NULL, 0, func1, &p1, 0, NULL);
    potok[1] = CreateThread(NULL, 0, func2, &p2, 0, NULL);
    
    //ждать 1 и 2 события
    swap(*it1, *it2);
    //инициализировать 3-е событие
    //WaitForMultipleObjects(2, potok, FALSE, INFINITE);
 
    return 0;
}
Изначально стояла задача о сортировке массива с помощью двух потоков (для 100% загрузки двухядерного процессора)
В приведённой выше программе делается предварительный шаг, чтобы получить массив вида
МЕНЬШЕ ЧИСЛА | ЧИСЛО | БОЛЬШЕ ЧИСЛА
а потом отдельно для 1 и 2 части вызвать независемые потоки. и получить отсортированный массив с помощью sort().
P.s. сортировка ОБЯЗАТЕЛЬНО с помощью sort
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 04:10. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru