या लेखात, आम्ही थ्रेड नियंत्रित करण्यासाठी प्रतीक्षा() पद्धत आणि notify() / notifyAll() पद्धती पाहू . या पद्धती बेस क्लास java.lang.Object मध्ये परिभाषित केल्या आहेत आणि त्यानुसार, Java मध्ये असलेल्या इनहेरिटन्स मेकॅनिझम या पद्धती पूर्णपणे सर्व वर्गांना प्रदान करतात. म्हणजेच, जेव्हा तुम्ही तुमचा स्वतःचा वर्ग आणि त्याचे ऑब्जेक्ट्स तयार करता तेव्हा तुम्ही या पद्धतींना नेहमी कॉल करू शकता.
प्रतीक्षा() आणि notify()/notifyAll() पद्धती कशा कार्य करतात?
- प्रतीक्षा करा() . थोडक्यात, ही पद्धत मॉनिटर रिलीझ करते आणि कॉलिंग थ्रेडला प्रतीक्षा स्थितीत ठेवते जोपर्यंत दुसरा थ्रेड notify() / notifyAll() पद्धतीला कॉल करत नाही;
- सूचित करा() . थ्रेडचे कार्य सुरू ठेवते ज्याची प्रतीक्षा() पद्धत पूर्वी कॉल केली गेली होती;
- notifyAll() मेथड सर्व थ्रेड्स पुन्हा सुरू करते ज्यांना पूर्वी त्यांची wait() पद्धत कॉल केली होती.
-
पब्लिक फायनल नेटिव्ह व्हॉइड वेट(लाँग टाइमआउटमिलिस) इंटरप्टेडएक्सेप्शन फेकते ; यामुळे वर्तमान थ्रेड जागृत होईपर्यंत प्रतीक्षा करावी लागते. सामान्यतः हे सूचित करून किंवा व्यत्यय आणून किंवा ठराविक वेळ संपेपर्यंत घडते.
-
सार्वजनिक अंतिम शून्य प्रतीक्षा() InterruptedException फेकते . आम्ही दुसरी पद्धत म्हणून पॅरामीटर्सशिवाय पद्धत लिहिली हा योगायोग नाही. खरं तर, जर तुम्ही त्याचा कोड पाहिला, तर तो पद्धतीच्या पहिल्या प्रकाराचा संदर्भ देतो, त्यात फक्त 0L युक्तिवाद आहे.
-
सार्वजनिक अंतिम प्रतीक्षा (दीर्घ कालबाह्य, इंट नॅनो) . वर्तमान थ्रेडला जागृत होईपर्यंत प्रतीक्षा करण्यास प्रवृत्त करते, विशेषत: सूचित करून किंवा व्यत्यय येईपर्यंत किंवा रिअल टाइमची ठराविक रक्कम संपेपर्यंत.
प्रतीक्षा () पद्धतीचे उदाहरण
येथे आम्हाला सर्वात लोकप्रिय उदाहरणांपैकी एक मिळाले आहे जी पद्धत कशी कार्य करते हे स्पष्ट करते. समजा आमच्याकडे एक स्टोअर, एक निर्माता आणि एक ग्राहक आहे. निर्माता उत्पादनाची काही उत्पादने स्टोअरमध्ये हस्तांतरित करतो, त्यानंतर ग्राहक त्यांना घेऊ शकतात. निर्मात्याला अनुक्रमे 8 वस्तू तयार कराव्या लागतील, ग्राहकाने त्या सर्व खरेदी केल्या पाहिजेत. परंतु त्याच वेळी, गोदामात एकाच वेळी 6 पेक्षा जास्त वस्तू असू शकत नाहीत. या समस्येचे निराकरण करण्यासाठी, आम्ही wait() आणि notify() पद्धती वापरतो. चला तीन वर्ग परिभाषित करू: बाजार , उत्पादक आणि ग्राहक . रन () पद्धतीतील उत्पादक त्याचा वापर करून मार्केट ऑब्जेक्टमध्ये 8 उत्पादने जोडतोput() पद्धत. लूपमधील रन() पद्धतीतील क्लायंट ही उत्पादने मिळविण्यासाठी मार्केट ऑब्जेक्टच्या गेट मेथडला कॉल करतो . मार्केट क्लासच्या पुट आणि गेट पद्धती समक्रमित केल्या आहेत. मार्केट क्लासमध्ये वस्तूंच्या उपस्थितीचा मागोवा घेण्यासाठी , आम्ही आयटम व्हेरिएबलचे मूल्य तपासतो. उत्पादन मिळविण्यासाठी get () पद्धत कमीतकमी एक उत्पादन असल्यासच सक्रिय केली पाहिजे. म्हणून, गेट पद्धतीमध्ये, आम्ही उत्पादन गहाळ आहे का ते तपासतो. आयटम उपलब्ध नसल्यास, प्रतीक्षा() पद्धत कॉल केली जाते. ही पद्धत मार्केट ऑब्जेक्टचे मॉनिटर रिलीझ करते आणि सूचना() होईपर्यंत गेट मेथड ब्लॉक करते.पद्धत समान मॉनिटरवर कॉल केली जाते. पुट() मेथडमध्ये आयटम जोडला जातो आणि notify() कॉल केला जातो, तेव्हा get() मेथड मॉनिटर मिळवते. त्यानंतर, आमच्या क्लायंटला एक आयटम प्राप्त होतो. हे करण्यासाठी, एक संदेश प्रदर्शित केला जातो आणि आयटमचे मूल्य कमी केले जाते. शेवटी, notify() मेथड कॉल पुट () मेथड चालू ठेवण्यासाठी सिग्नल करते. पुट() पद्धतीत , तत्सम लॉजिक कार्य करते, फक्त आता पुट() पद्धत जर मार्केटमध्ये 6 पेक्षा जास्त उत्पादने नसतील तर कार्य करते .
class Market {
private int item = 0;
public synchronized void get() {
//here we use wait() method
while (item < 1) {
try {
wait();
}
catch (InterruptedException e) {
}
}
item--;
System.out.println("A client has bought 1 item...");
System.out.println("Items quantity in Market warehouse... " + item);
notify();
}
public synchronized void put() {
//here we use wait() method when the Warehouse is full
while (item >= 6) {
try {
wait();
}
catch (InterruptedException e) {
}
}
item ++;
System.out.println("Manufacturer has added 1 more item...");
System.out.println("Now there are " + item + " items in Warehouse" );
notify();
}
}
class Manufacturer implements Runnable {
Market market;
Manufacturer(Market market) {
this.market = market;
}
public void run() {
for (int i = 0; i < 8; i++) {
market.put();
}
}
}
class Client implements Runnable {
Market market;
Client(Market market) {
this.market = market;
}
public void run() {
for (int i = 0; i < 8; i++) {
market.get();
}
}
}
//wait() method test class
public class WaitTest {
public static void main(String[] args) {
Market market = new Market();
Manufacturer manufacturer = new Manufacturer(market);
Client client = new Client(market);
new Thread(manufacturer).start();
new Thread(client).start();
}
}
येथे, get() पद्धतीमध्ये wait() वापरून, आम्ही निर्माता नवीन आयटम जोडण्याची वाट पाहत आहोत . आणि जोडल्यानंतर, आम्ही notify() ला कॉल करतो , जसे की वेअरहाऊसवर एक जागा मोकळी झाली आहे , आणि तुम्ही आणखी जोडू शकता. put() पद्धतीमध्ये wait() वापरून , आम्ही वेअरहाऊसवरील जागा सोडण्याची वाट पाहत आहोत . जागा मोकळी झाल्यानंतर, आम्ही आयटम जोडतो, notify() थ्रेड सुरू करतो आणि क्लायंट आयटम उचलू शकतो. आमच्या प्रोग्रामचे आउटपुट येथे आहे:
निर्मात्याने आणखी 1 आयटम जोडला आहे... आता वेअरहाऊसमध्ये 1 आयटम आहेत निर्मात्याने आणखी 1 आयटम जोडला आहे... आता वेअरहाऊसमध्ये 2 आयटम आहेत उत्पादकाने आणखी 1 आयटम जोडला आहे... आता वेअरहाऊसमध्ये 3 आयटम आहेत उत्पादकाने आणखी 1 आयटम जोडला... आता वेअरहाऊसमध्ये 4 आयटम आहेत उत्पादकाने आणखी 1 आयटम जोडला आहे... आता वेअरहाऊसमध्ये 5 आयटम आहेत उत्पादकाने आणखी 1 आयटम जोडला आहे... आता वेअरहाऊसमध्ये 6 आयटम आहेत एका क्लायंटने खरेदी केले आहे 1 आयटम... मार्केट वेअरहाऊसमध्ये वस्तूंची संख्या... 5 एका क्लायंटने 1 वस्तू खरेदी केली आहे... मार्केट वेअरहाऊसमध्ये वस्तूंची संख्या... 4 क्लायंटने 1 वस्तू खरेदी केली आहे... मार्केट वेअरहाऊसमध्ये वस्तूंची संख्या... 3 एका क्लायंटने 1 वस्तू खरेदी केली आहे... मार्केट वेअरहाऊसमध्ये वस्तूंची संख्या... 2 क्लायंटने 1 वस्तू खरेदी केली आहे... मार्केट वेअरहाऊसमध्ये वस्तूंची संख्या... 1 क्लायंटने 1 वस्तू खरेदी केली आहे... मार्केट वेअरहाऊसमध्ये वस्तूंचे प्रमाण ...0 निर्मात्याने आणखी 1 आयटम जोडला आहे... आता वेअरहाऊसमध्ये 1 आयटम आहे निर्मात्याने आणखी 1 आयटम जोडला आहे... आता वेअरहाऊसमध्ये 2 आयटम आहेत एका क्लायंटने 1 आयटम खरेदी केला आहे... मार्केट वेअरहाऊसमध्ये आयटमचे प्रमाण... 1 क्लायंटने 1 वस्तू विकत घेतली आहे... मार्केट वेअरहाऊसमध्ये वस्तूंचे प्रमाण... 0 एक्झिट कोड 0 सह प्रक्रिया पूर्ण झाली
GO TO FULL VERSION