Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / Java [игнор отключен] [закрыт для гостей] / синхронизация / 9 сообщений из 9, страница 1 из 1
26.05.2005, 16:38
    #33085682
J--
J--
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
синхронизация
Здравствуйте!
Немного туплю.
Синхронизация потоков - понятно, когда в одной функции - ее можно сделать
synchronized или секцию сделать synchronized.

А как лучше, если у нас надо потоки синхронизировать в разных
функциях - у меня в частности функции читатель и писатель в файлик.
Я помню в осях есть семафоры или мьютексы для этого, которые можно занять.
А здесь как порекомендуете, может сделать общий synchronized метод , который вызывать из каждой и таким образом будет синхронизация правильнее как-то по-другому?
...
Рейтинг: 0 / 0
26.05.2005, 16:50
    #33085738
wessen
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
синхронизация
Если в классе есть несколько синхронизированных методов, затем создается объект этого класса и когда какой либо поток войдет в любой из этих методов, то никакой другой поток не сможет войти в любой другой синхронизированный метод данного объекта. Т.е. блокируется Объект! точнее все synchronized методы.
Так что объявляй методы readFile and writeToFile как synchronized. Если они конечно в одном классе.
...
Рейтинг: 0 / 0
26.05.2005, 17:01
    #33085781
oracle79
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
синхронизация
Никаких проблем!!
Помещаем все функции, которые нужно синхронизировать в один класс.
Объект синхронизации - класс.
Наиболее правильным решением будет использование вызовов wait и notify, особенно если reader и writer работают с разной скоростью.
Должно получиться что-то типа этого :
Код: plaintext
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.
 class  ReadWrite {
        
         boolean  isWrited = false;
        
         synchronized   void  read() {
            
             if  (!isWrited)
                
                wait();

            isWrited = false;
            
            notify();
        }
        
         synchronized   void  Write( int  n) {
            
             if  (isWrited)
                
                wait();

            isWrited = true;
                 
            notify();
            
        } 
}
...
Рейтинг: 0 / 0
26.05.2005, 17:14
    #33085831
J--
J--
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
синхронизация
Спасибо!

Функции в разных классах и к тому же один из них - статический метод :)

Может это не очень правильный дизайн, но из-за чего - поясню - множество рабочих потоков периодически плюют в файл,
а один поток (этот статический как раз) периодически активизируется и все из файла сливает в базу и удаляет файл.
Вот эти моменты я и синхронизирую, т.е. писатели меж собой синхронизированы потому что synchronized метод а теперь буду прикручивать читателя исходя из ваших рекомендаций.
...
Рейтинг: 0 / 0
26.05.2005, 17:16
    #33085836
J--
J--
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
синхронизация
про wait и notify я как раз и забыл, наверное придется ими действительно
...
Рейтинг: 0 / 0
26.05.2005, 17:48
    #33085943
wessen
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
синхронизация
Можно тогда вот такой класс всавить (чтоб совсем было круто):
Код: plaintext
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.
/*
 * RWLock.java
 *
 * Created on 4 Март 2005 г., 11:27
 */

 package  cache;

 import  java.util.*;

 public   class  RWLock {
     private   int  givenLocks;
     private   int  waitingWriters;
     public   static   boolean  TRACE = false;
    
     private  Object mutex;
    
    
     public  RWLock() {
        mutex =  new  Object();
        givenLocks =  0 ;
        waitingWriters =  0 ;
         new  Date();
    }
    
     public   void  getReadLock(){
         synchronized (mutex){
             try {
                 while ((givenLocks == - 1 ) || (waitingWriters !=  0 )){
                    mutex.wait();
                }
            }  catch (java.lang.InterruptedException e){
                System.out.println(e);
            }
            givenLocks++;
        }
    }
    
     public   void  getWriteLock(){
         synchronized (mutex){
            waitingWriters++;
             try {
                 while (givenLocks !=  0 ){
                    mutex.wait();
                }
            }  catch (java.lang.InterruptedException e){
                System.out.println(e);
            }
            waitingWriters--;
            givenLocks = - 1 ;
        }
    }
    
    
     public   void  releaseLock(){
         synchronized (mutex){
            
             if (givenLocks ==  0 )
                 return ;
            
             if (givenLocks == - 1 )
                givenLocks =  0 ;
             else 
                givenLocks--;

            mutex.notifyAll();
        }
    }
}


Как пользоваться понятно?

ps Автор класса не я :) Из книжки Горький вкус Джава.
...
Рейтинг: 0 / 0
26.05.2005, 17:51
    #33085952
funikovyuri
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
синхронизация
Чтоб "совсем круто" нужно переходить на tiger Concurrency Utilities
...
Рейтинг: 0 / 0
26.05.2005, 17:51
    #33085955
J--
J--
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
синхронизация
Прикольно. Настоящий мьютекс прям-таки :-). Беру!

P.S. и чего они (SUN) не сделали мьютексы и теперь умные головы изобретают такие велосипеды...
...
Рейтинг: 0 / 0
26.05.2005, 17:56
    #33085971
wessen
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
синхронизация
funikovyuriЧтоб "совсем круто" нужно переходить на tiger Concurrency Utilities
Не доросли мы еще до Тигра :)
...
Рейтинг: 0 / 0
Форумы / Java [игнор отключен] [закрыт для гостей] / синхронизация / 9 сообщений из 9, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]