Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск  
 
 
Рейтинг 4.60/55: Рейтинг темы: голосов - 55, средняя оценка - 4.60
 Аватар для Vexel
12 / 12 / 2
Регистрация: 18.10.2009
Сообщений: 158

Разбить программу на потоки

09.09.2010, 01:44. Показов 10617. Ответов 24
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите пожалуйста разбить программу на потоки. Всего у нас три суммы в программе, т.е. должно быть три потока, которые в итоге выводят конечный результат. Проще говоря программа должна быть параллельной и иметь три потока. Вот я начал пробовать, но что-то не выходит.
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
#include <iostream>
#include <windows.h>
#include <pthread>
void * func_MyThread(void * args)
{
int S=0; //
int i;
int j;
int k; 
for (i=1; i <=8; i++)//
{
S +=i+1; //
}
int main (void)
{
pthread_t MyThread;
pthread_create(&MyThread,NULL,func_MyThread,NULL);
 
for (j=4; j <=12; j++)//
{
S+=j; //
}
for (k=5; k<=20; k++)
{
S += k*(2*k-1); 
}
pthread_join(MyThread,NULL);
std::cout <<"S= \t" <<S; //
return 0;// 
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
09.09.2010, 01:44
Ответы с готовыми решениями:

Разбить на потоки
Есть программа рабочая: #include &quot;stdafx.h&quot; #include &lt;cctype&gt; #include &lt;iostream&gt; #include &lt;fstream&gt; #include &lt;vector&gt; ...

Разбить коллекция на потоки(Многопоточность)
Добрый день всем! У меня есть коллекция из 20 объектов и 6 потоков. Вопрос : Как сделать так что бы объекты из коллекций брались и...

Сделать поиск с клавиатуры и разбить на потоки
Здравствуйте, помогите скорректировать данную задачу 1. поиск нужно осуществлять по данным введенным с клавиатуры 2. обернуть операции...

24
Эксперт С++
 Аватар для niXman
3211 / 1459 / 74
Регистрация: 09.08.2009
Сообщений: 3,441
Записей в блоге: 2
09.09.2010, 19:36
Студворк — интернет-сервис помощи студентам
Цитата Сообщение от Vexel Посмотреть сообщение
В итоге должно получиться число 5596
все понимаю... но результат-то, почему именно такой? объясните.
1
 Аватар для Vexel
12 / 12 / 2
Регистрация: 18.10.2009
Сообщений: 158
09.09.2010, 19:39  [ТС]
Цитата Сообщение от niXman Посмотреть сообщение
все понимаю... но результат-то, почему именно такой? объясните.
В последовательной программе из которой я делаю параллельную результат такой! Пересчитывал его в ручную, все верно!
0
Эксперт С++
 Аватар для niXman
3211 / 1459 / 74
Регистрация: 09.08.2009
Сообщений: 3,441
Записей в блоге: 2
09.09.2010, 20:31
ага. понял.

Добавлено через 50 минут
вот.
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
#include <iostream>
#include <pthread.h>
 
/***************************************************************************/
 
void* thread_func(void* p) {
   // извлекаем значение для этого потока
   int v = *(int*)p;
 
   // результат работы цикла, временно запишем в `S'
   int S = 0;
 
   // щитаем сколько нужно
   for ( int idx = 0; idx < v; ++idx ) {
      S += idx;
   }
 
   // результат записываем по адресу `p'
   *((int*)p) = S;
   return 0;
}
 
/***************************************************************************/
 
int main() {
   const int thcount = 3;
   // идентификаторы трех потоков.
   pthread_t threads[thcount] = {{0}};
   // значения для циклов кажого потока.
   int results[thcount] = {
      0, // для первого
      0, // для второго
      0  // для третьего
   };
 
   // создаем потоки.
   for ( int idx = 0; idx < thcount; ++idx ) {
      if ( pthread_create(&threads[idx], 0, thread_func, &results[idx]) ) {
         std::cerr << "error creating " << idx << "th thread"  << std::endl;
         return 1;
      }
   }
 
   // ждем завершения каждого их них.
   for ( int idx = 0; idx < thcount; ++idx ) {
      pthread_join(threads[idx], 0);
   }
 
   // потоки завершены.
   // считаем сумму значений.
   int sum = results[0] + results[1] + results[2];
 
   // выводим
   std::cout << "summ: " << sum << std::endl;
 
   // жмем клаву для выхода
   std::cin.get();
 
   return 0;
}
 
/***************************************************************************/
вопросы?
1
 Аватар для Vexel
12 / 12 / 2
Регистрация: 18.10.2009
Сообщений: 158
09.09.2010, 20:48  [ТС]
Почему сумма равна нулю в результате ?
0
Эксперт С++
 Аватар для niXman
3211 / 1459 / 74
Регистрация: 09.08.2009
Сообщений: 3,441
Записей в блоге: 2
09.09.2010, 21:18
Цитата Сообщение от niXman Посмотреть сообщение
0, // для первого
* * * 0, // для второго
* * * 0 *// для третьего
сюда подставь значения, сумма которых будет ровняться нужной тебе.

Добавлено через 39 секунд
и посмотри на тело thread_func()
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
09.09.2010, 21:18

Пытаюсь разбить на потоки алгоритм быстрой сортировки
Создал программу с одним потоком для алгоритма быстрой сортировки: #Программа в рамках одного созданного потока import threading as...

Найти слова в которых нет повторяющихся букв. Разбить на потоки.
Ребят, прошу помочь. Не понимаю этот С# вообще.

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

Оформить программу через потоки
Всем привет!! Помогите пожалуйста оформить программу через потоки!! ))) В программе поиск элемента оформить как функцию потока. Сначала...

Как разбить 1 программу на 2?
А именно обучающую программу, где есть возможности и для учеников и для преподов?


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

Или воспользуйтесь поиском по форуму:
25
Ответ Создать тему
Новые блоги и статьи
Сам себя обучал rest api
anaschu 02.07.2026
Педагогический лайфхак: Почему чистый REST API для ученика намного круче, чем готовые библиотеки Когда мы отказались от капризного JAR-файла AnyLogic и переписали код на стандартный HttpClient,. . .
rest api anylogic - выполнение модели на своём русском сайте
anaschu 02.07.2026
Как подружиться с AnyLogic Cloud API, победить провайдеров и развернуться Java-бэкенд в Docker на бесплатном хостинге: Двухдневный лог борьбы Всем привет! Хочу поделиться свежим (и довольно. . .
Где деньги лежат
kumehtar 02.07.2026
Это - японская подводная лодка I-52 (тип C2, кодовое имя Momi) вышла из Японии в марте 1944 года с миссией в оккупированную немцами Францию (Лорьян). Это была одна из «Янаги»-миссий по обмену. . .
Krabik для WoW 3.3.5a, многоязычный
AmbA 02.07.2026
Допилил бота, думаю что окончательно. Изменения: - добавлена многоязычность - добавлено снятие скриншотов - добавлено поддержание бафов хождения по воде (для жреца, дк и шамана) - и так, по. . .
Алиса нашла кучу ошибок компиляции и запуска в проекте, который без проблем компилировался и запускался)))
anaschu 30.06.2026
Я пока посмеюся, но завтра проверю. А вообще интерсно. Дал алисе файл, в котором точно нет ошибок компиляции и запуска, и попросил их найти. Нашла кучу))) Критические ошибки, мешающие компиляции и. . .
сукцессия 16. Общий обзор, в основном что бы другие ии поняли
anaschu 29.06.2026
# Передаточный документ: модель микоризной сукцессии (для нового чата) Этот документ предназначен для того, чтобы новый чат Claude мог продолжить работу без необходимости заново разбираться в. . .
сукцессия 15 неявная схема
anaschu 29.06.2026
Алиса Калибровка параметров симбиотической модели: технический обзор Содержание: Введение Постановка проблемы Технические аспекты реализации Процесс внедрения изменений
сукцессия 14. Обновленная схема модели
anaschu 28.06.2026
ГЛОБАЛЬНАЯ ОПИСАТЕЛЬНАЯ СПЕЦИФИКАЦИЯ ЭКОСИСТЕМНОЙ МОДЕЛИ «SOIL CHEMISTRY & MYCORRHIZA 2. 0» https:/ / ibb. co/ NnkGpfMd Представленная интегрированная схема описывает непрерывную нелинейную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru