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

Таймеры POSIX

24.12.2013, 21:07. Показов 1702. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет. Задание звучит так:
Программа-родитель запускает заданное число процессов, рассчитывающих значения элементарных функций от матриц, а затем по истечении заданного для каждого процесса времени проверяет, закончен ли процессом расчет.
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
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
#include <sys/types.h>
#include <sys/wait.h>
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include <iostream>
#include <time.h>
using namespace std;
 
int** mSum(int** A, int** B)
{
    int** S;
    S = new int*[10];
    for(int i=0; i<10; i++)
    {
        S[i] = new int [10];
    }
    for(int i=0;i<10;i++)
        for(int j=0;j<10;j++)
            S[i][j]=A[i][j]+B[i][j];
    return S;
}
 
int** mMultNum(int** A, int a)
{
    for(int i=0;i<10;i++)
        for(int j=0;j<10;j++)
            A[i][j]*=a;
    return A;
}
 
int** mMult(int**A,int**B)
{
    int** S;
    S = new int*[10];
    for(int i=0; i<10; i++)
    {
        S[i] = new int [10];
    }
    int sum=0, i,j,k;
    for (i = 0; i < 10; ++i) for (j = 0; j < 10; ++j) 
    {
        sum = 0; 
        for (k = 0; k < 10; ++k)         
            sum += A[i][k] * B[k][j];       
        S[i][j] = sum/2;
    }
    return S;
}
 
void prMas(int** A)
{
    for(int i=0;i<10;i++)
        for(int j=0;j<10;j++)
        {
            if (j==9) { cout<<A[i][j]<<endl;}
            else cout<<A[i][j]<<" ";
        }
}
 
int** mPow(int** A, int c)
{
    int**S; 
    for(int i=1;i<=c;i++)
    S=mMult(A,A);
    return S;       
}   
 
void del(int** B)
{
    for(int i=0; i<10; i++)
    {
        delete[] B[i];
    }
    delete[] B;
}
 
 
int main()
{
    int status, num, j,number;
    cout<<"Input number of processes: ";
    cin>>num;
    int*timemas = new int[num];
 
    int** A, **B,**S, sw;
    A = new int*[10];
    for(int i=0; i<10; i++)
    {
        A[i] = new int [10];
    }
    B = new int*[10];
    for(int i=0; i<10; i++)
    {
        B[i] = new int [10];
    }
    S = new int*[10];
    for(int i=0; i<10; i++)
    {
        S[i] = new int [10];
    }
 
    //for (j=0;j<num;j++) {cout<<"process "<<j+1<<" time: "; cin>>timemas[j]; }
 
    int*pid = new int[num]; for(j=0;j<num;j++) pid[j]=0;    
    
    srandom(time(0));
    for(int i=0;i<10;i++)
        for(int j=0;j<10;j++)
            A[i][j]= random()%100;
    for(int i=0;i<10;i++)
        for(int j=0;j<10;j++)
            B[i][j]= random()%100;
    for(int i=0;i<10;i++)
        for(int j=0;j<10;j++)
            S[i][j]= 0;
    
    
    for(int i = 0; i < num; i++)
    {
        pid[i]=fork();
        if (pid[i]==-1) perror("fork");
        if (pid[i]==0) 
            {   
                switch(i)
                {
 
                    case 0: 
                    cout<<"A + B = "<<endl;
                    S=mSum(A,B); 
                    prMas(S);  
                    break;
        
                    case 1: 
                    cout<<"A * B = "<<endl;
                    S=mMult(A,B); 
                    prMas(S);
                    break;
 
                    case 2: 
                    mMultNum(A,number=random()%10); 
                    cout<<number<<"*A = "<<endl; 
                    prMas(A); 
                    break;
                    
                    case 3: 
                    S=mPow(A,number=random()%10); 
                    cout<<"A^"<<number<<"="<<endl; 
                    prMas(S); 
                    break;
                }
            }
    }
    for(int i = 0; i < num; i++) waitpid(pid[i],&status,0); 
    
    
    return 0;
}
Подскажите плз, как сделать так, чтобы в дочернем процессе расчет проходил один раз? Бывают ситуации, когда выполняется один и тот же расчет несколько раз.
И помогите организовать для каждого процесса таймер. Заранее благодарен.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
24.12.2013, 21:07
Ответы с готовыми решениями:

Потоки Posix
Всем доброго времени суток . Хочу начать изучать потоки posix нашел книгу , там пример , написал его и не могу откомпилить его . ругается...

Аналог HANDLE в Posix.?
struct player new_player(HANDLE h_event, int process_id, int** field) { struct player p; p.h_event = h_event; p.process_id =...

Потоки Posix. C++ Linux
Начал изучать потоки posix. Нашел книгу в которой рассказано и показано как создавать потоки, синхронизация и т.п. Хотел бы узнать, как...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
24.12.2013, 21:07
Помогаю со студенческими работами здесь

Завершение потоков POSIX
Подскажите как корректно завершить потоки POSIX. допустим у меня есть класс Thread Thread.h #include &lt;pthread.h&gt; ...

Watchdog на основе таймеров POSIX
Добрый день, решил написать watchdog для сервера и чтобы не тратить зазря процессрное время решил реализовать это на основе таймеров POSIX,...

Системные вызовы согласно стандарту POSIX
Дайте, плз, ссылку на список системных вызовов согласно POSIX или сам (переведённый) стандарт. PS Гугление результатов не дало ((

Параллельное умножение матриц (POSIX потоки)
Всем привет. Пытаюсь программировать на C++ из под Linux. Есть задача: написать небольшой код программы параллельного умножения матриц с...

Отменяемые таймеры
Нужно создать отменяемый таймер. т.е. если таймер был запущен и до истечения заданного времени другая нить решила что таймер не нужен - он...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru