6 / 0 / 0
Регистрация: 01.10.2021
Сообщений: 23

Правильное высвобождение разделяемой памяти и мьютексов в многопотоке

19.04.2023, 20:55. Показов 1471. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть следующий код
Кликните здесь для просмотра всего текста

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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <fcntl.h>
#include <errno.h>
#include <signal.h>
#include <sys/mman.h>
#include <pthread.h>
 
#define SHARED_MEM_SIZE 64
#define MAX_CLIENTS 4
 
#define ERROR_EXIT(message)\
do\
{\
    perror(message);\
    exit(EXIT_FAILURE);\
} while(0);\
 
 
char *shared_mem[MAX_CLIENTS];
 
pthread_mutex_t mutex[MAX_CLIENTS];
 
void *process_client(void *arg) {
    int client_id = *(int *)arg;
    char *mem = shared_mem[client_id];
    while (1) {
    if (pthread_mutex_lock(&mutex[client_id]) != 0)
        ERROR_EXIT("pthread_mutex_lock");
 
        if (strlen(mem) > 0) {
            printf("Server received message from client %d: %s\n", client_id, mem);
        memset(mem, 0, SHARED_MEM_SIZE);
        }
 
    pthread_mutex_unlock(&mutex[client_id]);    
 
        sleep(1);
    }
    return NULL;
}
 
 
int main(int argc, char *argv[]) {
    if (argc < 2)
    ERROR_EXIT("Usage : ./server name\n");
 
    char *pid_str = argv[1];
    pthread_t threads[MAX_CLIENTS];
    int client_ids[MAX_CLIENTS];
    
    
    for (int i = 0; i < MAX_CLIENTS; i++) {
        char id_str[10];
        sprintf(id_str, "%d", i);
        char *mem_name = strcat(pid_str, id_str);
        int fd = shm_open(mem_name, O_CREAT | O_RDWR, 0666);
        ftruncate(fd, SHARED_MEM_SIZE);
        shared_mem[i] = mmap(NULL, SHARED_MEM_SIZE, PROT_READ | PROT_WRITE, MAP_SHARED, fd, 0);
        client_ids[i] = i;
    if (pthread_mutex_init(&mutex[i], NULL) != 0)
        ERROR_EXIT("initialize mutex");
        pthread_create(&threads[i], NULL, process_client, &client_ids[i]);
    }
    
for (int i = 0; i < MAX_CLIENTS; i++) {
    pthread_join(threads[i], NULL);
}
 
 
for (int i = 0; i < MAX_CLIENTS; i++) {
    pthread_mutex_destroy(&mutex[i]);
    munmap(shared_mem[i], SHARED_MEM_SIZE);
    char id_str[10];
    sprintf(id_str, "%d", i);
    char *mem_name = strcat(pid_str, id_str);
    shm_unlink(mem_name);
}
 
    exit(EXIT_SUCCESS);
}


Я не понимаю как сделать так, чтобы блок кода после join выполнился и ресурсы выделенные мной освободились. Я пробовал с помощью сигналов перехватывать SIGINT, но ловил Segmentation fault (возможно из-за того, что пытался очистить в самой функции обработчика сигнала). Как правильнее всего очистить ресурсы в данном случае?

Добавлено через 2 часа 6 минут
Ошибку нашёл и пофиксил.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
19.04.2023, 20:55
Ответы с готовыми решениями:

Высвобождение памяти массивов
Доброго времени суток! Такой вопрос: Как освободить выделенную память под массивы arr1, arr2, arr3? Все что пробовал, не работает. ...

Долгое высвобождение памяти
Здравствуйте. Возможно, такой вопрос уже встречался, но ответа мне найти не удалось. Намахал template List. ~List(){ Item *srh =...

Высвобождение памяти Free Си
В общем столкнулся с такой проблемой не могу высвободить область выделенной памяти . Пожалуйста помогите, а то в притык не вижу как все...

3
118 / 86 / 35
Регистрация: 07.11.2022
Сообщений: 355
19.04.2023, 22:19
Цитата Сообщение от Pontik Посмотреть сообщение
как сделать так, чтобы блок кода после join выполнился и ресурсы выделенные мной освободились.
освобождать в том же потоке, в котором и выделялись.
А у вас в коде ресурсы освобождаются в главном потоке.

======================================== ==

А что тут делают потоки, кто-нибудь сможет объяснить ?

Функция mmap отображает в адресное пространство процесса файл или объект разделяемой памяти.

То есть,
если один поток делает отображение памяти, то эта память видна всем потокам процесса.
Не придумаю, зачем делать отображение в разных потоках.
0
118 / 86 / 35
Регистрация: 07.11.2022
Сообщений: 355
20.04.2023, 10:14
Цитата Сообщение от NEED-A-JOB Посмотреть сообщение
освобождать в том же потоке, в котором и выделялись.
А у вас в коде ресурсы освобождаются в главном потоке.
Выделять ресурсы и освобождать в одном и том же потоке
C
1
2
3
4
5
6
7
8
9
10
11
12
void *process_client(void *arg) {
 
 // выделение ресурса  
 
 
//......................
 
 
// освобождение ресурса 
 
    return NULL;
}
Но пригляделся и теперь вообще не понимаю , что в коде происходит ...
0
267 / 199 / 30
Регистрация: 26.11.2022
Сообщений: 863
20.04.2023, 11:34
Цитата Сообщение от NEED-A-JOB Посмотреть сообщение
вообще не понимаю , что в коде происходит ...
ТС проверяет какую-то свою идею, которую он не сумел сформулировать ))
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
20.04.2023, 11:34
Помогаю со студенческими работами здесь

Высвобождение памяти компонента
Добрый вечер, снова я. Не подскажите как организовать следующее: допустим я создаю динамический компонент при создании формы, скажем так: ...

Высвобождение динамической памяти
Нужна помощь, в проблеме высвобождения памяти, все делаю по стандартам С++, но постоянно выдает ошибки. Фото 1, в случае, если пытаюсь...

Высвобождение памяти статического массива
Возник такой вопрос - память из под статических массивов высвобождается автоматически? То-есть допустим у нас есть следующий код: ...

Корректное высвобождение памяти в list
У меня все нормально работает, ну и по логике тоже вроде нормально, но намучился с Коректным высвобождением памяти(ну пару раз упала...

Высвобождение кешированной оперативной памяти
Всем привет. Можно ли как то высвободить кешированную оперативную память системы средствами С# ?


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru