С Новым годом! Форум программистов, компьютерный форум, киберфорум
C/С++ под Linux
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.69/16: Рейтинг темы: голосов - 16, средняя оценка - 4.69
1 / 1 / 1
Регистрация: 28.11.2010
Сообщений: 37

Мьютексы, взаимная блокировка процессов

30.04.2011, 16:23. Показов 3400. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
процесс1 два раза посылает данные процессу2 на обработку
C++
1
2
3
4
5
6
7
8
   while(i!=2)
       {
        pthread_mutex_unlock(mptr);       
        //.....     
        pthread_mutex_lock(mptr);
        //kill(pid,SIGCONT);
        i++;     
       }
процесс 2 зациклен на выполнение действия
C++
1
2
3
4
5
6
7
while(1)
{
    pthread_mutex_lock(mptr);
    //.....
    pthread_mutex_unlock(mptr);
    //pause();
}
по идее процесс1 один должен дать второму отработать одну итерацию и обратно захватить мьютекс
но на деле получается, что пр2, выполняет действие, возвращается в начало цикла и первым захватывает мьютекс, блокируя процесс1.
вставил для пр2 pause() на ожидание сигнала от пр1 (в комментарии), но это не дало видимого эффекта
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
30.04.2011, 16:23
Ответы с готовыми решениями:

Взаимная блокировка потоков
В одной из моих программ, наблюдается взаимная блокировка потоков. Судя по всему это происходит из-за обращения к SysListView32 из...

Не срабатывает взаимная блокировка
Изучаю многопоточность при запуски данного кода, всегда выводится два потока, компилятор никогда не блокируется,

Взаимная блокировка транзакций
Здравствуйте! Можно ли каким-либо образом на одном компьютере запустить две транзакции, которые будут блокировать друг друга?

4
бжни
 Аватар для alex_x_x
2473 / 1684 / 135
Регистрация: 14.05.2009
Сообщений: 7,162
30.04.2011, 19:25
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

на примере sem_t, на мьютексы сами перепишите
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
sem_t s_1, s_2;
sem_init( &s_1, 0, 1 );
sem_init( &s_2, 0, 0 );
 
// process 1
 
int i;
for( i=0;i!=2;++i )
{
  sem_wait( &s_1 );
  // write
  sem_post( &s_2 );
}
 
// process 2
int i;
for( i=0;i!=2;++i )
{
  sem_wait( &s_2 );        
  // read
  sem_post( &s_1 );
}
0
1 / 1 / 1
Регистрация: 28.11.2010
Сообщений: 37
30.04.2011, 19:54  [ТС]
я понял
но меня щас больше интересует, почему сигналы не работают
мне ведь нужна просто небольшая задержка для второго процесса, чтобы первый успел раньше схватить мьютекс (например c sleep(1) работает)
0
бжни
 Аватар для alex_x_x
2473 / 1684 / 135
Регистрация: 14.05.2009
Сообщений: 7,162
30.04.2011, 20:13
вам нужна не небольшая задержка, а правильная синхронизация
такими темпами можно и вообще без мьютексов обойтись
0
1 / 1 / 1
Регистрация: 28.11.2010
Сообщений: 37
02.05.2011, 15:33  [ТС]
у меня все равно не получается

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
//пр1
pthread_mutex_lock(mptr1); //захват м1 до запуска второго процесса
 //.....
 
   while(i!=2)
       {          
        // отправление данных
pthread_mutex_unlock(mptr1); //освобождение м1 (пр2 ждет этого, чтобы начать считывать данные) 
pthread_mutex_lock(mptr2);    //пр1 ждет пока пр2 выполнит свою работу
        // получение результата от пр2
        i++; 
pthread_mutex_lock(mptr1); 
pthread_mutex_unlock(mptr2); //на момент новой итерации, пр1 должен захватить м1 и освободить м2
       }
 
//пр2
pthread_mutex_lock(mptr2); //захват м2, чтобы пр1 не начал считывать результат раньше времени
//.....
while(1) 
{  
    pthread_mutex_lock(mptr1); //ожидание, пока пр1 пошлет данные
   //получение данных, выполнение действий, отправление результата
    pthread_mutex_unlock(mptr2); //освобождение м2, пр1 может получить результат
    pthread_mutex_unlock(mptr1); //освобождение м1, тк он больше не нужен, а пр1 должен его захватить
//в этом месте пр1 должен успеть захватить м2, получить результат , захватить м1 и освободить м2
    pthread_mutex_lock(mptr2); 
}
перепробовал несколько вариантов, проблемы каждый раз крутятся вокруг неправильной синхронизации, из-за чего в том или ином месте происходит взаимная блокировка
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
02.05.2011, 15:33
Помогаю со студенческими работами здесь

Многопоточность Java (Взаимная блокировка)
Есть пример public class Student { private ArrayList friends = new ArrayList(); public synchronized ArrayList getFriends() ...

Взаимная блокировка приложений с использованием семафоров
Доброго времени суток всем! Имеется такое задание: Искусственно создать взаимную блокировку потоков с использованием 2 объектов типа...

Не понимаю вырезку из книги (Взаимная блокировка)
Читаю книгу Энтони Уильямся "Паралельное программирование на С++". Но я не совсем понимаю следующий кусок (на картинке). Я понимаю...

Почему происходит взаимная блокировка потоков?
Код из Гербердта Шилдта, глава 11, класс Deadlock // An example of deadlock. class A { synchronized void foo(B b) { String...

Понятие синхронизации потоков и процессов. Семафоры и мьютексы
Хотелось бы обсудить и уточнить некоторые понятия: 1. Корректно ли следующее утверждение. Синхронизация - это обеспечение...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
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? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru