Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
0 / 0 / 0
Регистрация: 26.05.2012
Сообщений: 2

Много поточность

26.05.2012, 02:11. Показов 1086. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам

Написал программу по много поточности, которая состоит из двух файлов:
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
129
// Cycle
........................................
// реазизуем интерфейс Runnable
public class Cycle implements Runnable {
    // время на которое будет засыпать поток
    private final static int sleepTime = 50;
    // граница счетчика
    private final static int MAX = 1000000000;
    // глобальный счетчик
    private static int counter = 0;
    // переключалка потоков
    private static boolean check = false;
    // номер потока
    private int threadId;
    
    // инициализируем поток номером
    public Cycle(int id) {
        this.threadId = id;
    }
 
    public void run() {
        // счетчик итераций в методе
        int k = 0;
        
        // гарантируем что поток 1 начнет выполнение позже чем поток 0
        // начнем выполнять поток 1 как только нам разрешить это поток 0
        if (threadId == 1) {
            while (!check) {
                // пытаемся ловить исключение
                try {
                    Thread.sleep(sleepTime);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        }
 
         System.out.println(threadId);
        // итерируем цикл MAX раз
        while (k < MAX) {
            // если работает 1 поток на MAX позиции, останавливаем его пока
            // глобальный счетчик не станет отличным от MAX, т.е. выполнится
            // итерация в потоке 0
            if (threadId == 1 && k == MAX - 1) {
                while (counter == MAX - 1) {
                    try {
                        Thread.sleep(sleepTime);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
            }
            
            // присваиваем переменной глобальный счетчик 
            int tmp = counter;
            
            // если первый раз итерируется 0 поток, то останавливаем его пока первый
            // поток не проитерируется MAX - 1 раз
            // разрешаем запуск 1 потока
            // сохраняем за потоком значение tmp = 0
            if (threadId == 0 && k == 0) {
                check = true;
                while (counter != MAX - 1) {
                    try {
                        Thread.sleep(sleepTime);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
            }
            
            // увеличиваем счетчик цикла
            tmp++;
            
            // останавливаем первый поток до тех пор, пока не завершит выполнение 0 поток
            // значение tmp = 2, мы выведем его в конце
            if (threadId == 1 && k == MAX - 1) {
                check = false;
//                while (counter != MAX) {
//                    try {
//                        Thread.sleep(sleepTime);
//                    } catch (InterruptedException e) {
//                        e.printStackTrace();
//                    }
//                }
            }
            
            // присваиваем глобальному счетчику значение счетчика цикла
            counter = tmp;
            
            // если выполняется 0 поток на первой итериации, то останавливаем его пока
            // не выполнится часть итерации 1 потока
            // даем разрешение дальше выполняться 1 потоку на MAX итерации
            // присваиваем counter = 1
            if (threadId == 0 && k == 0) {
                check = true;
                while (check) {
                    try {
                        Thread.sleep(sleepTime);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
            }
            k++;
        }
        // выводим значение глобального счетчика и номер потока
        System.out.println(threadId + ": " + counter);
    }
}
 
 
 
...........................................
 
 
Solution
 
 
public class Solution {
    public static void main(String[] args) throws InterruptedException {
        // создаем 2 потока, в каждом свой экземпляр класса Cycle и запускаем их
        Thread[] threads = new Thread[2];
        for (int i = 0; i < threads.length; i++) {
            threads[i] = new Thread(new Cycle(i));
            threads[i].start();
        }
    }
}
на выходе выдает:

0
1
1: 2
0: 1000000001

Process finished with exit code 0

что нужно сделать, чтобы вывело
1
0
1: 2
0: 1000000001

И если в программу добавить 3-й поток, то counter = 2 или 3?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
26.05.2012, 02:11
Ответы с готовыми решениями:

Много-поточность
Сделал Proxy Парсер по ссылкам и что бы форма не зависала переместил в отдельный поток. Мужики, знатоки в потоках помогите решить...

std::unordered_map и много-поточность
Можно ли обращаться к объекту std::unordered_map одновременно из разных потоков? У меня ключ это ид потока, и когда что-то делаем то...

Много поточность вызывает ошибку счета
Хотел реализовать многопоточность в коде для ускорения счета и столкнулся со следующим. Естественно сначала испытывал последовательный код...

1
Эксперт С++
 Аватар для Avazart
8488 / 6155 / 615
Регистрация: 10.12.2010
Сообщений: 28,683
Записей в блоге: 30
26.05.2012, 05:52
Код не отформатирован тяжело читать (да и еще походу не весь)

Интуитивно догадываюсь что ты пытаешся выводить данные генерируемые разными потоками без их синхронизации в этом и проблема.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
26.05.2012, 05:52
Помогаю со студенческими работами здесь

Как реализовать поточность (threading) ?
Subj, как ее сделать, где про нее почитать и т.д.?

Аппаратные ключи. Их много. Как привязать к дистрибутивам, которых тоже много
Начну с вводных данных: имеется: 1) гора дисков 1С 7.7 торговля+склад (предположительно не сетевые). На каждом диске стоит какой-то...

Что лучше: 1 цикл и много действий или много циклов и 1 действие?
Есть n количество данных. Есть m количество действий. Задание надо выполнить m действий с каждой единицей данных n. По сути решения 2: 1)...

Хочу один системник и много-много мониторов+клавиатур+мышей. Как?
Вопрос: как реализовать возможность одновременной работы на одном системнике нескольким людям одновременно (человек 5-6), т.е. системник...

Много методов или много классов. Что лучше?
Имеется библиотека(ActiveX DLL), в которую, в своё время, было решено складировать функции, вызваемые извне(точнее, основным модулем)....


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru