Overview of Operating Systems
- Introduction: The video aims to cover the entire Operating Systems syllabus in 6 hours, focusing on important topics for semester exams. For those new to the subject, you might find the Introduction to Linux: A Comprehensive Guide for Beginners helpful as it provides foundational knowledge relevant to operating systems.
- Target Audience: Ideal for students who are new to Operating Systems or those preparing for competitive exams and placements.
Key Topics Covered
- Definition of Operating Systems: Acts as an intermediary between users and hardware, resource manager, and provides a platform for application programs.
- Goals and Functions: Discusses primary and secondary goals of Operating Systems, including user convenience and efficiency.
- Evolution of Operating Systems: Covers batch processing, spooling, and multiprogramming.
- Process Management: Explains process states, process control blocks (PCBs), and process scheduling algorithms (FCFS, SJF, Priority, Round Robin).
- Memory Management: Discusses memory allocation strategies, paging, segmentation, and virtual memory concepts. For a deeper understanding of memory management, you may also want to check out the Comprehensive Overview of the New PPS Course for Second Semester.
- Disk Scheduling: Covers various disk scheduling algorithms, including FCFS, SSTF, SCAN, and LOOK.
- File Management: Discusses file organization methods, including sequential, linked, and indexed allocation.
- Deadlock Handling: Explains necessary conditions for deadlock, prevention, avoidance, detection, and recovery strategies.
- Thread Management: Discusses the concept of threads, user-level vs kernel-level threads, and their advantages.
Frequently Asked Questions (FAQs)
-
What is an Operating System?
An Operating System is software that acts as an intermediary between users and computer hardware, managing resources and providing a platform for applications. -
What are the main functions of an Operating System?
The main functions include managing hardware resources, providing user interfaces, and ensuring efficient execution of applications. -
What is the difference between paging and segmentation?
Paging divides memory into fixed-size blocks, while segmentation divides memory into variable-sized segments based on logical divisions. -
What is a deadlock?
A deadlock occurs when two or more processes are unable to proceed because each is waiting for the other to release resources. -
How can deadlocks be prevented?
Deadlocks can be prevented by ensuring that at least one of the necessary conditions for deadlock cannot hold, such as mutual exclusion or hold and wait. -
What is the purpose of disk scheduling?
Disk scheduling aims to optimize the order of disk access requests to minimize seek time and improve overall system performance. -
What is the significance of threads in Operating Systems?
Threads allow for concurrent execution within a process, improving efficiency and resource utilization by sharing the same memory space. For those looking to enhance their skills in related areas, consider exploring Mastering Excel 2019: Perform Operations Using Formulas and Functions as it can provide useful insights into data management and analysis.
हेलो एवरीवन इस वीडियो में पूरा ऑपरेटिंग सिस्टम कंप्लीट करेंगे सिक्स आवर्स में स्पेशली फॉर योर सेमेस्टर एग्जाम्स मैंने
इस वीडियो में बताया है कि एग्जाम पॉइंट ऑफ व्यू से कौन-कौन से टॉपिक्स इंपॉर्टेंट है और वहां से एगजैक्टली क्या क्वेश्चंस
पूछे जाते हैं कुछ लोग को हो सकता है वीडियो थोड़ा लंबा लगे बट एक्चुअली वीडियो छोटा है यहां मैंने अपने 15 साल का पूरा
एक्सपीरियंस यूज किया है जिसमें मैंने ऑपरेटिंग सिस्टम 50 बार से ज्यादा पढ़ाया है इस वीडियो में आपको पूरा ऑपरेटिंग
सिस्टम स्टार्टिंग से लेकर एंड तक मिलेगा तो अगर इससे पहले आपने ऑपरेटिंग सिस्टम कभी नहीं पढ़ा है तो वीडियो आपके लिए एकदम
परफेक्ट है अगर ऑपरेटिंग सिस्टम पहले थोड़ा पढ़ा है या कॉम्पिटेटिव एग्जाम के लिए प्रिपेयर कर रहे हैं प्लेसमेंट्स के
लिए प्रिपेयर कर रहे हैं या रिवीजन करना चाहते हैं तो भी ये वीडियो आपके लिए बड़े काम का साबित होगा मैंने यहां पर बहुत
सारे यूनिवर्सिटीज और कॉलेज का पूरा सिलेबस स्टडी करने के बाद कंटेंट फाइनल किया है तो पूरे विश्वास से बोल सकता हूं
9095 पर से ज्यादा सिलेबस मैच होगा अगर आप यह पूरा वीडियो कंप्लीट करते हैं तो आप ऑपरेटिंग सिस्टम सीख जाओगे इस बात की
गारंटी देता हूं इस वीडियो में मैंने जो भी कंटेंट कवर किया है उसका एकदम प्रो लेवल का नोट्स आपके लिए एकदम फ्री है
जिसका लिंक आपको डिस्क्रिप्शन में मिलेगा अभी नीचे आप चैप्टर देख सकते हैं जहां पर क्लिक करके आप किसी भी इंपॉर्टेंट टॉपिक
पर डायरेक्ट पहुंच सकते हैं भारत में किस जगह से आप ये वीडियो देख रहे हैं कमेंट सेक्शन में जरूर कमेंट करिएगा ताकि पूरे
भारत का एक नक्शा कमेंट सेक्शन में मैं दिखने लगे तो चलिए शुरू करते हैं सो डायरेक्टली जंपिंग ऑन टू द सिलेबस जैसे
मैंने आपसे बोला कि हमने देश के जितने बड़े यूनिवर्सिटीज हैं कॉलेजेस हैं उन सबका लेबस स्टडी किया है एंड दैट इज अ आई
थिंक मोर और लेस द कॉमन पार्ट ऑफ इट जिसमें 95 पर से ज्यादा एक दो टॉपिक ऊपर नीचे हो सकते हैं मैं हट जाता हूं ये
सिलेबस है है ना आपकी यूनिवर्सिटी में हो सकता है एक यूनिट ऊपर हो एक यूनिट नीचे हो एक टॉपिक आगे पीछे हो बट मोटा-मोटा यह
सिलेबस है जो इस वीडियो में हम कवर करेंगे अब किस ऑर्डर में कवर करेंगे ना लुक एट दिस सो द देयर विल बी 12 चैप्टर्स जो आप
नीचे टाइमलाइन देखते हैं ना उसमें आपको ये सारे चैप्टर्स नजर आएंगे फ्रॉम चैप्टर नंबर वन टू चैप्टर नंबर 12 थ्रू आउट द
वीडियो इटल अराउंड अ सिक्स आवर्स वीडियो तो कंफ्यूजन ना हो आप जल्दी से नेविगेट कर पाएं पहले तो आप इसका स्क्रीनशॉट ले लीजिए
बिकॉज़ दिस इज़ द ऑर्डर जो हम फॉलो कर रहे होंगे अब आईडिया क्या है पूरी वीडियो में टॉप लेफ्ट के ऊपर आपको चैप्टर नंबर मिलेगा
एंड यहां पे टॉप राइट के ऊपर आपको इस ऑर्डर में फिलहाल कौन सा टॉपिक चल रहा है वो दिखने वाला है सो दैट जब भी आप नेविगेट
करें इफ यू वांट टू गो इन टू अ स्पेसिफिक टॉपिक डायरेक्टली आप बड़े आराम से वो कर सके बट ऑब् वियस इट इज एडवाइजेबल एक बार
कम से कम पूरा वीडियो कंप्लीट देखना इस ऑर्डर में बिकॉज़ दे अ इंपोर्टेंट आईडिया मैंने यू नो जैसे मैं बोल रहा हूं 50 बार
से ज्यादा ऑपरेटिंग सिस्टम पढ़ा चुका हूं इस ऑर्डर में क्यों पढ़ाया वो जब आपको समझ आएगा जब आप ये वीडियो देखेंगे यस सो नाउ
डायरेक्टली जंपिंग ऑन टू द टॉपिक सबसे पहले डेफिनेशन या आईडिया जो आपको पता होना चाहिए व्हाट इज ऑपरेटिंग सिस्टम अलग-अलग
बुक्स में अलग-अलग तरह से चीजों को डिफाइन किया गया डेफिनेशन दी गई है अगर फिर भी मैं दो-तीन चार सबसे इंपॉर्टेंट पॉइंट
कंक्लूजन है एग्जाम में लिख के आना है तो ध्यान दीजिएगा सबसे पहला पॉइंट है इट एक्ट्स एज
एन इंटरमीडिएट री वेरी इंपॉर्टेंट पॉइंट तो एक तरफ हमारा यूजर है एक तरफ हमारा हार्डवेयर है दोनों के बीच में यहां पर एज
अ इंटरमीडिएट काम करने वाला ऑपरेटिंग सिस्टम तो यूजर को हार्डवेयर को कोई भी इंस्ट्रक्शन अगर देनी है तो वह हार्डवेयर
से डायरेक्ट बात नहीं करेगा ऐसा करेगा तो वह इनएफिशिएंट भी होगा और कन्वेनिएंट भी नहीं होगा तो यहां पर यूजर बात करेगा ओएस
से और ओस आपके बिहाव पे बात करेगा हार्डवेयर से सिमिलरली हार्डवेयर से जो भी रिस्पांस आएगा वह भी डायरेक्ट यूज़र को
नहीं आएगा वह ने वाला है पहले ऑपरेटिंग सिस्टम को और ऑपरेटिंग सिस्टम से रिस्पांस जाएगा यूजर के पास तो इट एक्टस एज अ
इंटरमीडिएट बिटवीन द हार्डवेयर एंड द यूजर पॉइंट नंबर वन पॉइंट नंबर टू जो कि अगेन उतना ही इंपॉर्टेंट है यह काम करता है एज
अ रिसोर्स मैनेजर एज अ रिसोर्स एलोकेटर देखो सिस्टम में किसी भी इंस्टेंस में बहुत सारे प्रोसेस हैं बहुत सारे अलग-अलग
तरह के रिसोर्स हैं और गेम क्या है कि रिसोर्स के लिए कंपीट किया जा रहा है तो ऑपरेटिंग सिस्टम हमारे बिहाव पे यूजर के
बिहाव पे क्या करेगा किसी को सीपीयू टाइम चाहिए किसी को मेमोरी चाहिए किसी को सिस्टम बसेस चाहिए किस प्रोसेस को कितना
रिसोर्स एलोकेट करना है फिलहाल वह सारा का सारा जो मैकेनिज्म है वो यहां पर हमारे बिहाव में कौन तय करता है ऑपरेटिंग सिस्टम
तय करता है तो अगेन सेकंड इंपॉर्टेंट पॉइंट ऑपरेटिंग सिस्टम कंट्रोल एंड कोऑर्डिनेट्स यू नो द यूज़ ऑफ सिस्टम
रिसोर्सेस अमंग वेरियस एप्लीकेशन प्रोग्राम्स इन एन अनबाय फैशन तो रिसोर्स मैनेजमेंट का काम करेगा तीसरा पॉइंट यहां
पर आ जाता है इट प्रोवाइड्स अ प्लेटफॉर्म देखो हार्डवेयर के ऊपर जैसा हमने समझा एक मात्र कंट्रोल है किसका ऑपरेटिंग सिस्टम
का अब हमारा जो वीएलसी मीडिया प्लेयर है यू नो ऑफिस है जितने भी एप्लीकेशन एडिटर्स हैं जो भी हम सॉफ्टवेयर यूज करते हैं वो
किससे बात करेंगे वो भी ऑपरेटिंग सिस्टम से ही बात करेंगे तो ऑपरेटिंग सिस्टम यहां पर एक प्लेटफॉर्म हमें देगा और ऑपरेटिंग
सिस्टम इन सारे के सारे जो भी हमारे यू नो सॉफ्टवेयर्स हैं उन सबको रन करेगा उनकी जो भी रिसोर्स रिक्वायरमेंट हो सबको फुलफिल
करेगा तो अगेन इट प्रोवाइड्स अ प्लेटफॉर्म ऑन व्हिच अनदर ऑ अनदर एप्लीकेशन प्रोग्राम्स कैन बी इंस्टॉल्ड एंड
प्रोवाइड्स एन एनवायरमेंट इन व्हिच द प्रोग्राम्स आर एग्जीक्यूटेड तो ऑपरेटिंग सिस्टम के तीन इंपॉर्टेंट आइडियाज आपको
समझ आए इंटरमीडिएट है पॉइंट नंबर वन देन इट एक्सस अ रिसोर्स मैनेजर रिसोर्स एलोकेट करता है पॉइंट नंबर टू एंड थर्ड इज इट
प्रोवाइड्स अ प्लेटफॉर्म जिसके ऊपर बाकी एप्लीकेशन प्रोग्राम हमारे इंस्टॉल होंगे काम करेंगे एग्जांपल की बात करूं तो कोई
नया नहीं है इसे स्मार्ट बोर्ड में भी विज यूज़ कर रहा हूं उसके अलावा ए है मैक है आओ है
हो जाते हैं हमारे किसके ऑपरेटिंग सिस्टम के यस अभी बात करते हैं गोल्स और फंक्शंस के बारे में अभी गोल्स क्या है जैसे मैं य
लिखता हूं गोल्स आर द अल्टीमेट डेस्टिनेशन बट वी फॉलो फंक्शन टू इंप्लीमेंट द गोल्स तो रियल लाइफ में होता है ना कुछ हमारे
गोल्स होते हैं कि यार ये हमारे लॉन्ग टर्म गोल्स हैं लेकिन गोल्स बोलने से तो कंप्लिशन हो नहीं जाएंगे अब मान लीजिए फॉर
एग्जांपल किसी का गोल है कि उसको यूपीएससी क्लियर करना दैट इज अ गोल क्या करना पड़ेगा मे बी कोई प्रोफेशनल कोचिंग जॉइन
करनी पड़ेगी पूरा सिलेबस कंप्लीट करना पड़ेगा रिवीजन लगाना पड़ेगा टेस्ट सीरीज लिखनी पड़ेगी मॉक इंटरव्यूज देने पड़ेंगे
ो दीज ऑल आर द फंक्शंस तो जब सारा सिलेबस कंप्लीट करोगे एक-एक फंक्शन पूरा करोगे तब कहीं जाके आपका गोल अंपलिंग फॉर एग्जांपल
आपको यूनिवर्सिटी एग्जाम में सेमेस्टर्स में ऑपरेटिंग सिस्टम कम समय में अच्छे नंबर से पास करना ना दैट इज अ गोल व्हाट
इज द फंक्शन ये वीडियो पूरी कंप्लीट करनी पड़ेगी तब वो गोल अंप्स होगा एक और एग्जांपल जैसे मान लीजिए हम बोलते हैं
गवर्नमेंट ऑफ इंडिया है अब गवर्नमेंट ऑफ इंडिया का लॉन्ग टर्म गोल क्या है लॉन्ग टर्म गोल आपने ना भी होगा बोलते हैं ना
बारबार सबका साथ सबका विकास बट बोलने से होगा क्या बोलने से नहीं होगा क्या करना पड़ेगा सो देर आर दे यू सी देयर आर 58
मिनिस्ट्री देयर आर 93 डिपार्टमेंट्स जब ये सारे मिनिस्ट्री सारे डिपार्टमेंट सब लोग मिलजुलकर अच्छे से अपनी अपनी ड्यूटी
परफॉर्म करेंगे तो ऑटोमेटिक गोल अंपलिंग यस तो आई थिंक गोल और फंक्शन में क्या रिलेशन है आपको बात समझा होगा नाउ कमिंग
टू ऑपरेटिंग सिस्टम हमारे गोल्स हम दो कैटेगरी में रखते हैं एक हम बोलते हैं प्राइमरी गोल एक बोलते हैं सेकेंडरी गोल
नाउ व्हाट इज प्राइमरी गोल प्राइमरी गोल है कन्वीनियंस और यूजर फ्रेंडली सुनने में थोड़ा अजीब लगेगा बट यहां मैं एफिशिएंसी
की बात नहीं करते कोई भी सॉफ्टवेयर हो अगर कोई सॉफ्टवेयर यूज करने में आसानी नहीं है अगर एक आम आदमी उसका इस्तेमाल नहीं कर पा
रहा तो नोबडी इज गोइंग टू यूज इट ये तो एक फैक्ट है तो हमारा कोई भी सिस्टम होता है इवन सम सॉफ्टवेयर यू टेक और इवन द
ऑपरेटिंग सिस्टम प्राइमरी गोल हमेशा याद रखिएगा क्या होगा यूजर फ्रेंडली स कन्वीनियंस ये हुआ प्राइमरी नाउ सेकेंडरी
की बात कर करेंगे तो एफिशिएंसी है रिलायबिलिटी है मेंटेनेबिलिटी है और मेंटेनेंस है ये सब का सब हो जाएगा
सेकेंडरी गोल ये दो गोल हुए हमारे प्राइमरी और सेकेंडरी यस अबी अंपलिंग तो जैसे गवर्नमेंट ऑफ इंडिया में अलग-अलग
डिपार्टमेंट्स हैं ऑपरेटिंग सिस्टम में भी अलग-अलग डिपार्टमेंट है जो काइंड ऑफ आपका सिलेबस भी है तो यहां पर आप देखेंगे
प्रोसेस मैनेजमेंट है मेमोरी मैनेजमेंट है इनपुट आउटपुट डिवाइस मैनेजमेंट है फाइल मैनेजमेंट है एंड देन नेटवर्क मैनेजमेंट
है एंड देन लास्ट वी हैव सिक्योरिटी एंड प्रोटेक्शन तो जब सारे के सारे डिपार्टमेंट्स सारे के सारे मॉड्यूस
अपना-अपना ड्यूटी परफॉर्म करेंगे जिसमें मैं आपको बताऊं प्रोसेस मैनेजमेंट तो हम बहुत अच्छे से पढ़ना है प्रोसेस क्या होता
है सीपीयू शेड्यूलिंग है डेडलॉक है सिंक्रोनाइजेशन है बात करेंगे मेमोरी मैनेजमेंट की तो यू नो प्राइमरी मेमोरी
मेन मेमोरी सेकेंडरी वर्चुअल मेमोरी डिस्क लोकेशन वो सारी पॉलिसीज डिस्कस करना इनपुट आउटपुट डिवाइस फाइल जब ये सारे के सारे
फंक्शंस ऑपरेटिंग सिस्टम अच्छे से परफॉर्म करेगा तो जो गोल्स हमने समझे थे कन्वीनियंस का और एफिशिएंटली रिसोर्स
यूटिलाइजेशन का वो ऑटोमेटिक अंपलिंग कुछ जगह यूनिवर्सिटी एग्जाम्स में सेमेस्टर्स में मैंने अलग से क्वेश्चन भी देखा है
व्हाट आर द मेजर कंपोनेंट्स ऑफ ऑपरेटिंग सिस्टम तो मैंने अलग से भी दो स्लाइड बना के रखी हैं यू कैन टेक द स्क्रीनशॉट जहां
पे हेडिंग बाय हेडिंग ताकि नंबर आपको शानदार मिले तो कर्नल ऑपरेटिंग सिस्टम का वो काम जो एक्चुअली मैनेजमेंट कर रहा होता
है दैट इज नोन एज कर्नल कोर पार्ट ऑफ द ऑपरेटिंग सिस्टम तो कर्नल है प्रोसेस मैनेजमेंट के अंदर हेडिंग्स आपके पास है
प्रोसेस शड ड्यूलर पीसीबी कॉन्करेंस कंट्रोल आगे जाके इस पे डिटेल में बात करेंगे देन इनसाइड मेमोरी मैनेजमेंट
फिजिकल मेमोरी वर्चुअल मेमोरी मेमोरी एलोकेशन फाइल सिस्टम अलोंग विद द सब हेडिंग्स देन व्हाट डू वी हैव डिवाइस
मैनेजमेंट अलोंग विद सब हेडिंग्स डिवाइस मैनेजर्स है ड्राइवर्स हैं एंड देन सिक्योरिटी एंड एक्सेस कंट्रोल ऑथेंटिकेशन
ऑथराइजेशन एंक्रिप्शन देन यूजर इंटरफेस कमांड लाइन एंड जीआई आगे सब की डिटेल में बात करूंगा अभी एंड देन नेटवर्किंग तो ये
एक इंपॉर्टेंट क्वेश्चन है आई होप गोल्स ऑफ फंक्शनैलिटीज के बारे में कोई बात करेगा तो नाउ दैट क्वेश्चन इज रेडी तो
चलिए अभी बात करते हैं ऑपरेटिंग सिस्टम की इवोल्यूशन इवोल्यूशन का क्या मतलब है देखिए स्टार्टिंग में आज ज हम जैसा
ऑपरेटिंग सिस्टम इस्तेमाल करते हैं क्या स्टार्टिंग से ऐसा ही है नहीं बहुत सारे स्टेजेस हमने पार किए जहां पे दो तीन
इंपॉर्टेंट आइडियाज हमें पढ़ने हैं बैच ऑपरेटिंग सिस्टम क्या होता है या बैच प्रोसेसिंग क्या होती थी देन स्पूलिंग एक
बहुत इंपॉर्टेंट आईडिया है एंड देन वी गो टू मल्टी प्रोग्रामिंग तो मैं बहुत बेसिक से और बहुत शॉर्ट में बात करूंगा सबसे
पहले बात कर लेते हैं बैच ऑपरेटिंग सिस्टम के बारे में देखो स्टार्टिंग के जो कंप्यूटर थे ना वो इंटरेक्ट नहीं थे तो
आईडिया क्या था आईडिया ये था अर्ली कंप्यूटर्स आर नॉट इंटरेक्ट डिवाइसेज सो यूजर यूज टू प्रिपेयर अ जॉब अब यहां मैं
प्रोसेस शब्द का इस्तेमाल नहीं कर रहा मैं क्या कह रहा हूं जॉब जॉब क्या होता है तो देर यू सी जॉब के अंदर तीन चीजें होती थी
क्या-क्या एक हमारा होता है प्रोग्राम एक होगा कंट्रोल इंफॉर्मेशन एक है इनपुट डाटा फॉर एग्जांपल मान लीजिए हमें कैलकुलेटर का
प्रोग्राम बनाया तो पहले तो कैलकुलेटर का प्रोग्राम लिखेंगे उसके बाद अगर कोई कंट्रोल इंफॉर्मेशन देनी है मान लीजिए फॉर
एग्जांपल यूजर से पूछना है कि डू यू वांट टू डू एडिशन सब्सट्रैक्शन मेथ यू नो मल्टीप्लिकेशन डिवीजन तो वो भी आपको अभी
बताना पड़ेगा देन इनपुट डाटा अगर कोई इनपुट डाटा रन टाइम पे कोई इंटरेक्ट वने स नहीं होगी तो जो भी मान लीजिए हमें एडिशन
करना है तो किन दो डाटा के बीच में एडिशन करना है वो भी हम अभी देंगे तो प्रोग्राम कंट्रोल इंफॉर्मेशन इनपुट डाटा जब ये
तीनों चीजें हमारे पास आ जाती इनका जो बंडल होता था उसको हम बोलते थे जॉब अब जब यह जॉब होगा तो एक बार में एक जॉब हम
इनपुट कराएंगे कोई मेमोरी सिस्टम के अंदर नहीं होती तो रन टाइम पे इनपुट होगा देन सिस्टम उसको प्रोसेस करेगा और प्रोसेस
करने के बाद वो आउटपुट जनरेट करेगा इस तरह के डिवाइसेज है ना तो कॉमन इनपुट आउटपुट डिवाइस आज की तरह कीबोर्ड या ये सब नहीं
होते थे लाइक दिस पंच कार्ड्स तो आप देख सकते एक तरह के टाइपिस्ट है ये टाइप राइटर जैसे होता है ना कार्ड होता था उसमें कई
जगह हम होल पंचर करते थे एंड देन उसके थ्रू लाइट पास होती थी तब डिटेक्ट होता था कि इनपुट डाटा और तब हम उसे प्रोसेस करते
थे तो ये एक बेसिक कहानी थी अब ऑब् वियस इनके साथ काम करना बहुत स्लो था एक बार में हम एक ही प्रोसेस के ऊपर एक ही जॉब के
ऊपर काम करते थे आंसर भी हमें यह पंच कार्ड की फॉर्म में ही मिलता था फिर कोई आदमी बैठ के उसको इंटरप्रेट करता था और तब
रिजल्ट आता था अब बैच ऑपरेटिंग सिस्टम में हमने क्या किया एक बेसिक सा दिमाग लगाया मान लीजिए अलग-अलग प्रोग्रामिंग
लैंग्वेजेस हैं उनके अलग-अलग पंच कार्ड्स हैं तो हमने क्या किया हमने जो सिमिलर टाइप के जॉब्स थे उन उनको कंबाइन करना
उनका एक बैच बनाना स्टार्ट कर दिया तो जैसे यहां पे डायग्राम में देख रहे हैं अलग-अलग यूजर हैं वो अलग-अलग जॉब जनरेट कर
रहे हैं नाउ देर इज अ ऑपरेटर और ऑपरेटर क्या कर रहा है जैसे फॉर एग्जांपल फोन के जॉब्स को एक साथ रख लिया कोबोल के जॉब्स
को एक साथ रख लिया और वो जो सिमिलर टाइप के जॉब्स का जो बंडल था उसी को हम यहां पर बैच कहके बुला रहे थे तो लेट मी से दिस इज
बैच वन लेट मी से दिस इज बैच टू और कंप्यूटर जो है पहले एक बैच के सिमिलर टाइप के जितने जॉब्स है उनको एग्जीक्यूट
करेगा फिर दूसरे सिमिलर टाइप के जितने जॉब्स हैं उनको एग्जीक्यूट करेगा तो जो प्रोसेसिंग थी वो रिलेटिवली थोड़ी सी
फास्ट जरूर हो जाएगी इसी मैनेजमेंट को इसी अंडरस्टैंडिंग को हम बोल देते हैं बैच ऑपरेटिंग सिस्टम तो बैच क्या था बैच हमने
बनाया जॉब से क्यों बनाया क्योंकि वो सिमिलर टाइप के प्रोग्रामिंग लैंग्वेज के अंदर हमने लिखे थे है ना तो आज के बाद अगर
कोई आपसे बैच की बात करेगा आप बता सकते हो जॉब क्या था तीन चीजों का कॉमिनेशन था इनपुट आउटपुट डिवाइसेज बहुत स्लो थे एक
बार में हम एक के ऊपर ही काम करते थे उस उसको स्पीड अप करने के लिए हमने सिमिलर टाइप के जॉब्स का बंडल बनाना स्टार्ट कर
दिया उसको हम बोलने लगे बैच बट स्टिल ये जो डिवाइसेज थे ना ये ओवरऑल जो प्रोसेसिंग थी बहुत स्लो थी और विद टाइम हमने समझा
स्लो क्यों थी उसका जो सॉल्यूशन है वो है स्पूलिंग स्पूलिंग की बात करता हूं देखिए रन टाइम पे हमारे जो इनपुट आउटपुट
डिवाइसेज होते हैं ना दे आर रिलेटिवली वेरी वेरी स्लो कंपेयर टू अ प्रोसेसर अब प्रोसेसर काम करता है यार मेगाहर्ट्ज पे
गिगा हर्ट्ज पे इजेंट इट 10 रे टू पावर 9 आप कीबोर्ड से कितनी स्पीड से टाइप कर कर लोगे क्या कभी प्रोसेसर को मैच कर पाओगे
कभी नहीं कर पाओगे तो स्पूलिंग का अगर मैं बहुत सिंपल शब्दों में आपको आईडिया बताऊं जो भी इनपुट आउटपुट डिवाइसेज है लेट मी से
दिस इज इनपुट डिवाइस लेट मी से दिस इज आउटपुट डिवाइस तो इनपुट डिवाइस का जो डाटा है वो मेन मेमोरी के थ्रू होते हुए सीधे
जाएगा डिस्क में जिसे आज हम सेकेंडरी मेमोरी या वर्चुअल मेमोरी बोल रहे होते हैं तो काइंड ऑफ जो सेकेंडरी मेमोरी का
अंडरस्टैंडिंग है वो हमने यहां पे एक्सप्लोर किया देन जो भी डाटा चाहिए वो सेकेंडरी टू मेन मेमोरी काम होता रहेगा
एंड देन रिजल्ट भी हम यहीं पे स्टोर करेंगे और यहीं से आंसर वापस जाएगा जिससे प्रोसेसर को जब भी डाटा चाहिए ना उसको
इनपुट आउटपुट डिवाइस पे डिपेंड होने की जरूरत नहीं है वाया डिस्क वाया दिस स्टोरेज ये मेन मेमोरी के थ्रू प्रोसेसर
तक पहुंचेगा आईडिया इज साइमल पेनियस पूलिंग इज एन एक्रोनिल शॉर्ट फॉर्म है किसका साइमल नियस पेरिफेरल ऑपरेशंस ऑनलाइन
ये पेरिफेरल मतलब इनपुट आउटपुट साइमल पेनियस एक बार में एक से ज्यादा ऑनलाइन मतलब लगातार कर सकते हैं तो लॉजिक क्या था
क्योंकि अब इनपुट आउटपुट डिवाइसेोकंट्रोल कॉमन इनपुट डिवाइसेज आर प्रिंटर्स व्हिच
आर वेरी स्लो रिलेटिव टू द रेस्ट ऑफ़ द सिस्टम पता है यह बात हमें स्पूलिंग इज अ प्रोसेस इन व्हिच अ डाटा इज टेंपरेरिली
हेल्ड इन अ मेमोरी और अ वोलेटाइल स्टोरेज टू बी यूज बाय अ डिवाइस और अ प्रोग्राम बाद में यूज़ करने के लिए वहां पे हम किसी
डिस में स्टोर करते हैं जैसे एक बहुत आसान एग्जांपल देखिए प्रिंटर का कई बार होता है ना हमने कोई प्रिंट कमांड सेंड कर दी तो
क्या सीपीयू लगातार बैठ के उसको प्रिंट कराता है नहीं तो वो कमांड ऑलरेडी प्रिंटर में जाके स्टोर हो गई है प्रिंटर के क्यू
में कंप्यूटर अभी कुछ भी अलग से काम कर सकता है जो उसको प्रोसेसिंग करनी है करेगा एंड देन वन बाय वन यह प्रिंटर जो है
प्रिंट करता जाएगा कीबोर्ड्स में कई बार आपने ऐसा देखा होगा आपने चार पाच छह क्री प्रेस की प्रेस कर दी बट आउटपुट नहीं आया
वो कई बार क्या होता है स्टोरेज में जाके स्टोर हो जाता है आउटपुट कमांड चली गई है एंड देन बाद में आप देखेंगे एक साथ चार
पाच छह लेटर टाइप हो जाता है तो ये जो पूरा मैकेनिज्म है ये था स्पूलिंग यहां पर हमने कुछ हद तक जो स्पीड मिसमैच वाला
प्रॉब्लम था इनपुट आउटपुट का डिवाइसेसपोर्ट कर लिया लेकिन कुछ प्रॉब्लम अभी भी है वो क्या था प्रॉब्लम था यूनि
प्रोग्रामिंग जिसको हमने रिजॉल्व किया बाय द आईडिया ऑफ मल्टी प्रोग्रामिंग जिसने पूरी कहानी बदल के रख दी प्रॉब्लम क्या
समझाता हूं देखो आईडिया क्या है मेन मेमोरी के अंदर एक हमारा ऑपरेटिंग सिस्टम है और नॉर्मली होता क्या है एक प्रोसेस हम
लेते हैं उसको रन करना स्टार्ट करते हैं जैसे मैं स्पूलिंग की बात कर रहा था बैच की बात कर रहा था ड्यूरिंग द एग्जीक्यूशन
हो सकता है उस प्रोसेस को कुछ इनपुट आउटपुट ऑपरेशन करना पड़े किसी दूसरे इवेंट के लिए वेट करना पड़े अब आमतौर पे अगर
मल्टी प्रोग्रामिंग नहीं है तो सीपीयू क्या करता है था सीपीयू वेट करता है क्या ठीक है तेरे को जो भी इनपुट आउटपुट करना
है तो अपना कंप्लीट कर ले उस उसके बाद मैं एग्जीक्यूट करूंगा बट उससे सीपीयू का टाइम वेस्ट होता है तो मल्टी प्रोग्रामिंग क्या
आईडिया है मल्टी प्रोग्रामिंग कहता है मैं एक बार में बहुत सारे प्रोसेसेस को मेन मेमोरी में लोड करके रखूंगा सीपीयू विल
पिक वन प्रोसेस मान लीजिए प्रोसेस नंबर ए लिया उठाना एग्जीक्यूट करना चालू किया बट ड्यूरिंग द एग्जीक्यूशन अगर वो प्रोसेस
किसी भी इवेंट के लिए वेट करने की बात करता है इनपुट आउटपुट की बात करता है तो सीपीयू आपके लिए वेट नहीं करेगा सीपीयू
तुरंत कांटेक्ट स्विच करेगा विल पिक सम अदर प्रोसेस किसी दूसरे प्रोसेस को लेकर रन करना चालू करेगा फिर उसको रन करेगा फिर
बहुत समय तक वेट नहीं करेगा अगर उसने किसी और चीज के लिए वेट किया मैं फिर से मेन मेमोरी से एक प्रोसेस लूंगा उसको रन करता
जाऊंगा आईडिया क्या है सीपीयू कभी आइडियल नहीं रहेगा जब तक मेन मेमोरी में एक भी प्रोसेस बची एग्जीक्यूट करने के लिए ध्यान
रखिएगा एक और बात कुछ लोग सोचते हैं मल्टी प्रोग्रामिंग का मतलब है एक बार में एक से ज्यादा प्रोसेस एग्जीक्यूट करना नहीं
सीपीयू में एक बार में एक ही प्रोसेस एग्जीक्यूट हो रही है लेकिन मैं मेन मेमोरी में एक से ज्यादा प्रोसेस रख के
बैठा हूं और उनके बीच में स्पीड से कांटेक्ट स्विच करता हूं तो हमें लगता है कि यार शायद बहुत सारी प्रोसेस रन हो रही
है तो लेट मी गो पॉइंट बाय पॉइंट बहुत सारी जॉब्स आ मिट मेन मेमोरी में रख ली एक प्रोसेस लिया उसको रन करना स्टार्ट किया
इवेंचर आउटपुट या किसी और चीज के लिए वेट कराएगा सीपीयू किसी के लिए वेट नहीं करेगा प्रोसेसर किसी के लिए वेट नहीं करेगा दैट
इज द आईडिया अगर य नॉन मल्टी प्रोग्राम होगा तो सीपी बेचारा चुपचाप बैठा रहेगा बट मल्टी प्रोग्रामिंग क्या कह कहता है
चुपचाप नहीं बैठना कोई दूसरा प्रोसेस लेंगे रन करना चालू करेंगे और अगर वह प्रोसेस किसी चीज के लिए वेट करता हो तो
तब अगला उठाएंगे कंक्लूजन इज द शो मस्ट गो ऑन जब तक एक भी प्रोसेस मेन मेमोरी में है जॉब क्यू में है रेडी क्यू में है जो
एग्जीक्यूट होना चाहता है तब तक सीपीयू आइडल नहीं रहेगा इसके कुछ इंपॉर्टेंट एडवांटेज एग्जाम में आता है इसको अच्छे से
लिख के आइएगा तो क्या-क्या ओबवियसली सीपी यूटिलाइजेशन अच्छा होगा अगर जल्दी-जल्दी सबका नंबर आएगा तो वेटिंग टाइम कम होगा एक
से ज्यादा टास्क आप हैंडल कर पा रहे होंगे एक बार में एक ही हो रहा होगा बिकॉज़ ऑफ द कॉन्टेक्स्ट स्विच वाला आईडिया और
ओबवियसली सीपीयू को जो टाइम है शेयर्ड हो रहा है बहुत सारे प्रोसेस के बीच में कुछ कॉम्प्लेक्शन तो आएंगी लाइक प्रोसेस
कॉम्प्लेक्टेड एंड कॉम्प्लेक्शन मैनेजमेंट तो सीपीयू को अच्छे से आपको मैनेज करना पड़ेगा उसके लिए आगे हम एल्गोरिथम स्टडी
करेंगे नॉट अ प्रॉब्लम एंड देन कॉम्प्लेक्टेड मेंट ये बात ठीक है मेन मेमोरी को बड़ा एफिशिएंट तरह से मैनेज
करना उसके लिए पेजिंग और बहुत सारे एल्गोरिथम हम आगे जाके सीखेंगे तो तीन आइडियाज हमने पढ़ ली इवोल्यूशन के अंदर
फर्स्ट इज बैच देन स्पूलिंग एंड देन दिस आइडिया ऑफ मल्टी प्रोग्रामिंग तो अभी बात करते हैं बहुत सारे नाम है मल्टीटास्किंग
टाइम शेयरिंग मल्टी प्रोग्रामिंग विद राउंड रॉबिन या फेयर शेयर आमतौर पे भी से मल्टीटास्किंग सो मल्टी प्रोग्रामिंग और
मल्टीटास्किंग टू बी वेरी ऑनेस्ट वैसे लगभग लगभग सेम चीज है थोड़ा सा लॉजिकल एक्सटेंशन है क्या समझाता हूं आपको और कई
बार इस पे यूनिवर्सिटी एग्जाम में सेमेस्टर्स में बात की जाती है देखिए आईडिया क्या है जब हमने मल्टी
प्रोग्रामिंग की बात की तो हमने समझा कि यार प्रोसेसर के पास बहुत सारी प्रोसेस है और जैसे ही उसको लगेगा कि किसी प्रोसेस को
वेट करना है किसी भी चीज के लिए इनपुट आउटपुट के लिए किसी और चीज के लिए तो सीपीय तुरंत कांटेक्ट स्विच करेगा बट
आईडिया अप्रोच समझिए क्या है ऐसा लगता है समझने में हमारी थॉट प्रोसेस क्या है कि सीपीयू तो रन करना चाहता है अगर प्रोसेस
ही एक समय के बाद रन नहीं होना चाहता तो सीपीयू अपना ऑप्शन एग्जीक्यूट कर रहा है तब वो किसी और को लेके आ रहा है बट क्या
ऐसा हो सकता है कि कोई प्रोसेस लगातार मे भी रन करना चाहता हो लेकिन फिर भी हम उसको जबरदस्ती रोक के किसी दूसरे प्रोसेस पर
जाएं फोर्सफुली कांटेक्ट स्विच करें यस इसी को हम बोलते हैं टाइम शेयरिंग अप्रोच ऐ समझिए जैसे फॉर एग्जांपल हमारा सिस्टम
है आज के टाइम पे सीपीयू है अब कोई यूजर बहुत सारे काम करता है आजकल के टाइम प मे बी आप यू नो ब्राउजर भी आपने खोला हुआ है
जैसे इस फिगर में देख रहे हैं एक्सल फाइल है कोई पेंट ब्रश है कोई गाना भी प्ले किया जा रहा है अब प्रोसेसर हम मानते हैं
कि आजकल के टाइम प बहुत पावरफुल है टास्क छोटे-छोटे हैं तो क्या करता है प्रोसेसर बहुत स्पीड से इन सारे टास्क में कांटेक्ट
स्विच करता जाता है बिकॉज एजेंडा ये तो है नहीं कि पहले गाना बजा के कंप्लीट कर लो गाना भी बैकग्राउंड में चलता रहे आप एक्सल
में कुछ एंट्रीज भी करते रहो और मे भी शायद कोई ब्राउजर भी ओपन रहे तो लॉजिक क्या है सीपीय इन सारे प्रोसेस के बीच में
इतने स्पीड से कांटेक्ट स्विच करता है ना कि एवरीबॉडी केटेड फॉर हिज और हर यूज एक ही चीज के लिए
पूरा सिस्टम है बट एक्चुअली वो यू नो सीपीयू जल्दी-जल्दी कांटेक्ट स्विच कर रहा होता है आपको लगेगा पैरेलल एग्जीक्यूशन हो
रहा है यहां भी पैरेलल एग्जीक्यूशन नहीं है बट स्पीड इतनी फास्ट है कि ऐसा लग रहा होता है तो इसको हम बोलते हैं टाइम
शेयरिंग या मल्टीटास्किंग एक और पॉइंट है हम यहां पर ऐसा भी मान सकते हैं कि टास्क भी अलग-अलग लोगों के हो सकते हैं मान
लीजिए google2 है नहीं बट सर्वर इतना पावरफुल है कि वो बहुत सारे यूजर्स के बीच में इतने
स्पीड से कांटेक्ट स्विच कर रहा है कि हर किसी को इंप्रेशन आ रहा है कि यार शायद हमारे लिए काम कर रहा है तो वही पूरा
आईडिया मैंने यहां पर लिखा है सो अ टाइम शेयरिंग और मल्टीटास्किंग इज अ लॉजिकल एक्सटेंशन ऑफ मल्टी प्रोग्रामिंग उसी का
एक्सटेंडेड वर्जन है इट अलाउ मेनी यूजर टू शेयर कंप्यूटर साइमल नियस सीपीयू एग्जीक्यूट मल्टीपल जॉब्स जो अलग-अलग यूजर
से हो सकते हैं एंड अगेन इतनी स्पीड से कांटेक्ट स्विच होता है कि हर किसी को इंप्रेशन आता है कि पूरा सिस्टम जैसे वही
यूज़ कर रहा है इवन दो वो सच में शेयर हो रहा है अगेन जैसे अब mp3 प्लेयर mp4 कर लीजिए डॉक्यूमेंट है कुछ भी यहां बहुत
सारे काम कर रहे होते हैं अगेन दोबारा समझिए क्या यहां पर भी ट्रू पैरेललिज्म है नहीं सीपीयू पर एक बार में एक ही प्रोसेस
एग्जीक्यूट हो रहा है बट हम इतने फास्टली इतनी स्पीड से कर रहे हैं कि मानो हर किसी को इंप्रेशन हो रहा है कि एक सारा एक साथ
हम बहुत सारा काम कर पा रहे हो यस सो दिस इज द आइडिया ऑफ मल्टी प्रोग्राम मल्टी टास्किंग या टाइम शेयरिंग ठीक है तो ये
अगेन इस जीआईएफ के अंदर ये करके दिखाने की कोशिश की कि बहुत सारा काम हम कर रहे हैं कमिंग टू नेक्स्ट आईडिया इज मल्टी
प्रोसेसिंग अब मल्टी प्रोग्रामिंग या मल्टीटास्किंग एक बात हो गई वह अलग कैटेगरी है यह अलग कैटेगरी है मल्टी
प्रोसेसिंग यह क्या है उल्टा मानते हैं देखो मल्टी प्रोग्रामिंग या मल्टीटास्किंग में हम क्या मान रहे हैं लोड इतना ज्यादा
है नहीं सीपीयू बहुत पावरफुल है इसलिए वो बड़ी स्पीड से कांटेक्ट स्विच कर रहा है और हर किसी को एक साथ मैनेज कर रहा है अगर
कहानी उल्टी समझे लोड बहुत ज्यादा और सीपीयू इतना पावरफुल नहीं है अब मेरे पास क्या ऑप्शन है आइर आई कैन हैव मल्टीपल
कंप्यूटर्स बहुत सारे कंप्यूटर में लगाऊं और उनसे मिलके काम करूं बट द फैक्ट ऑफ द मैटर इज ना तो मेरे को मेमोरी की जरूरत है
एक्स्ट्रा ना मेरे को इनपुट आउटपुट बसेस की जरूरत है ना मेरे को प्रिंटर की जरूरत है मेरे को तो कंप्यूटेशन करने की जरूरत
है तो क्यों ना एक काम करें कि एक ही सिस्टम के अंदर जहां पे मेमोरी भी एक ही होगी इनपुट आउटपुट डिवाइसेज भी सेम होंगे
बट वी कैन हैव मल्टीपल प्रोसेसर्स तो यहां पर सच में हम पहली बार एक सिस्टम में एक से ज्यादा प्रोसेसर लगाते हैं और इसको
बोलते हैं मल्टी प्रोसेसिंग नॉट मल्टी प्रोग्रामिंग वी है मल्टी प्रोसेस सो व्हाट इज द
आईडिया मल्टी प्रोसेसर ऑपरेटिंग सिस्टम रेफर्स टू यूज ऑफ टू और मोर सीपीयूज विद इन द सेम कंप्यूटर द मल्टीपल सीपीयू शेयर
बाकी सब कुछ सेम है उसको रिप्लिकेट नहीं कर रहे सो बसेस है मेमोरी है पेरीफेरल्स है सब कुछ यहां पे एक साथ ही है क्या यहां
पर ट्रू पैरेललिज्म होगा हां हुआ क्योंकि एक प्रोसेसर में एक बार में एक प्रोसेस रन कर सकती है बट अभी तो भाई मेरे पास एक से
ज्यादा प्रोसेसर है ना हां बिल्कुल है सो मल्टीपल कॉन्करेंट प्रोसेस कैन रन ऑन सेपरेटली ऑन ईच सीपीयू तो यहां पे ट्रू
पैरेललिज्म आपको मिलेगा अब यह करने का एडवांटेज क्या होगा ऑब्स जो कॉम्प्लेक्शन इंटेलिजेंस एक्सपर्ट सिस्टम
इमेज प्रोसेसिंग वेदर फॉर कास्टिंग वो सारे काम करने में आपको आजादी मिलती है फैक्ट बताऊं आजकल आपके भी जो प्रोसेसर है
इवन यू नो यू नो द प्रोसेसर्स ऑन सिंपल लैपटॉप्स पर्सनल कंप्यूटर्स में ऑक्टा कोर क्वार्ड कोर आपने सुना होगा इट मींस अगेन
दे आर हैविंग मल्टीपल कोर्स और मल्टीपल सीपीयूज इजंस यह एक आईडिया हुआ अगर मैं एक बार इसमें फर्द जाएं तो दो कैटेगरी होती
हैं एक होता है क्या सिमेट्री प्रोसेसिंग एक है असमेट व्हाट डू वी मीन बाय दिस एक तरीका तो यह है कि फॉर एग्जांपल चार
प्रोसेसर हैं चारों एकदम सिमिलर है सबके राइट सेम है ड्यूटी सेम है आपस में दिल मैनेज एक काइंड ऑफ़ मास्टर स्लेव
आर्किटेक्चर असमेट आइडिया एक मास्टर हो सकता है जो बाकी सारे प्रोसेस को प्रोसेसर्स को मैनेज करें उनको टास्क बताए
या और बहुत सारे कैटेगरी इजेशन हो सकते हैं तो आई विल गो वन बाय वन डेफिनेशन ऑल प्रोसेस डिड इक्वली एंड कैन
रन एनी टास्क जो भी टास्क आपस में मैनेज किया जा सकता है ईच प्रोसेसर इज असाइन ए स्पेसिफिक टास्क और अ रोल फॉर एग्जांपल
प्रिंटर हो सकता है सिर्फ एक प्रोसेसर से एसोसिएटेड हो तो अगर कोई प्रोसेस ऐसी आई जिसको की प्रिंटिंग करना है तो उसको उस
स्पेसिफिक प्रोसेसर पे ही शेड्यूल करना पड़ेगा या एक मास्टर है बाकी सारे स्लेव्स है अगेन जैसे टास्क लोकेशन एनी प्रोसेसर
कैन परफॉर्म एनी टास्क कोई यहां पे से कैटेगरी इजेशन नहीं होगा टास्क आर डिवाइडेड अकॉर्डिंग टू प्रोसेसर रोल एक हो
सकता है इनपुट आउटपुट को हैंडल कर रहा हो एक हो सकता है इमेज प्रोसेसिंग को हैंडल कर रहा हूं लाइक दिस
कॉम्प्लेक्शन सिंपलर फॉर ऑल प्रोसेसर्स एंड आर ट्रीटेड एज अ सेम लगभग सबकी कॉम्प्लेक्टेड करना और इन जनरल भी मुश्किल
होगा क्योंकि भाई एक मास्टर और बाकी सारे स्लेव हैं ये डिफरेंस यूनिवर्सिटी एग्जाम्स में बहुत काम आता है सेमेस्टर्स
में ना इसलिए इसको अलग से मेंटेन करके चल रहा हूं इसमें ऑब्स की स्केलेबल करना ना भी आसान होगा फ्यूचर में मैं 8 की जगह 16
या 32 कोर पे जाना चाहता हूं यहां पर मे एक बार कॉन्फ़िगरेशन एज प्रोसेसर्स आर डेड क्योंकि सबका एजेंडा अलग-अलग है तो हो
सकता है उसको आपको री कॉन्फ़िगर करना पड़े परफॉर्मेंस लोड आ लोड इज इवनली डिस्ट्रीब्यूटर और यहां पर अगेन मे वेरी
कुछ प्रोसेसर हो सकता है ज्यादा काम करें कुछ कम काम करें बेस्ड ऑन कि आप उससे क्या काम करा रहे हो क्या उसकी ड्यूटी है ये एक
इंपॉर्टेंट पॉइंट एक और मैंने सोचा डिफरेंस अलग से आपको एक्सप्लेन कर दूं मल्टी प्रोग्रामिंग एंड मल्टी प्रोसेसिंग
दोनों अलग-अलग आईडिया मल्टी प्रोग्रामिंग सीपीयू एक ही होता है मल्टीपल प्रोग्राम चलते हैं एक के बाद एक के बाद एक फास्ट
कॉन्टेक्ट स्विच यहां पर सच में मल्टीपल सीपीयूज हमारे पास होते हैं सिमुलेटर एट एग्जीक्यूशन ब रेपिडली तो कॉन्करंसी होती
नहीं है इल्यूजन सिमुलेशन है उस चीज का यहां पर सच में ट्रू पैरेललिज्म होता है क्योंकि यार प्रोसेसर एक से ज्यादा है
मेरे पास अ मैक्सिमाइज सीप यूटिलाइजेशन बाय कीपिंग बिजी विथ डिफरेंट टास्क को तो हमने समझ लिया जब तक एक भी टास्क रहेगा तब
तक हम एग्जीक्यूट करेंगे प्रोसेस कोई पंगा करेगी कांटेक्ट स्विच करेंगे यहां पर एन हैंस परफॉर्मेंस बाय अलोंग टास्क टू बी
प्रोसेस साइमल नियस मल्टीपल टास्क एक साथ होता है उस तरह से हम मैक्सिमाइज करते हैं सीपीय एकसे ज्यादा है रिक्वायर ओनली वन
सीपीयू मैनेज मल्टीपल टास्क ऑन इट रिक्वायर मल्टीपल सीपीयू इनेबल पैरेलल प्रोसेसिंग एंड द लास्ट इज़
कॉम्प्लेक्टेड होगा क्योंकि एक ही सीपीयू उसे ही हैंडल करना है अब यहां पर मल्टीपल सीपीयूज
वेदर इट इज सिमेट्री और असमेट कॉम्प्लेक्शन सिंगल प्रोसेसर से तो ज्यादा होने वाली है तो अगर आपसे इस तरह का
डिफरेंस पूछे मेक अ टेबल डिफरेंस बताओ और ज्यादा नंबर मिलेंगे रियल टाइम ऑपरेटिंग सिस्टम बहुत इंपॉर्टेंट बात है यह समझिए
आई एजेंडा क्या है एजेंडा है टाइम कुछ कंडीशंस कुछ आईडियाज ऐसे हो सकते हैं जहां पे सिर्फ टास्क करना जरूरी नहीं है विद इन
द स्पेसिफिक टाइम फ्रेम करना जरूरी है अगर इतने टाइम में किया तो किया अगर उसके बाद करोगे तो फिर उसका करना ना करना बराबर
होगा इस तरह के सिनेरियो को हम बोलते हैं रियल टाइम ऑपरेटिंग सिस्टम्स जहां पर इस तरह की कंडीशन को हम एंटरटेन करते हैं सो
व्हाट आर यू राइट इट अ रियल टाइम ऑपरेटिंग सिस्टम इज अ स्पेशल पर्पस ऑपरेटिंग सिस्टम व्हिच हैज वेल डिफाइंड फिक्स टाइम
कांस्टेंट्स टाइम की बड़ी स्पेसिफिक कंडीशन होंगी प्रोसेसिंग मस्ट बी डन विद इन द डिफाइंड टाइम कांस्टेंट और द सिस्टम
विल फेल या तो विद इन द टाइम स्पैन आप वो काम पूरा करो वरना ना करना ना करना बराबर होगा जैसे फॉर एग्जांपल आप देख सकते हैं
एयरक्राफ्ट है कोई कोई उसके ऊपर वेपन है अभी जब तक मैं एनिमी टेरिट्री में हूं फॉर एग्जांपल या एनिमी एयरक्राफ्ट हमारी
टेरिट्री में हम उसको मार सकते हैं वो अपने घर चला गया फिर दोबारा थोड़ी मार सकते हैं तो विद इन फ्रैक्शन ऑफ सेकंड
आपको फायर करना है वहां ऐसा नहीं कि आपने बटन दब विंडोज अपडेट पे चली गई कि अभी विंडो अपडेट कर रहा है उसके बाद करेगा
मेडिकल सिस्टम है अभी देख रहे इतना कॉम्प्लेक्शन अप है भाई तो अगर फॉर एग्जांपल किसी को कोई उसका बी बीपी डाउन
हो रहा है देयर मस्ट बी अ बजर और ऑटोमेटिक कोई मशीन है जिसको काम करना चाहिए उसको प्रॉब्लम को सॉल्व करने के लिए और वो आप
बोलो कि वो हमने किया लेकिन वो एक घंटा बाद किया एक घंटे में तो आदमी निकल चुका है ना भाई तो उसका ध्यान रखना है
एयरक्राफ्ट है एयरक्राफ्ट पूरा एटीसी है तो रन टाइम पे किसी को लैंडिंग करानी है किसी की इमरजेंसी कोई काम करना है तो ये
सारे के सारे टास्क ऐसे हैं जो आज के टाइम पे कंप्यूटर ही हैंडल कर रहा है बट टाइम बड़ा कांस्टेंट्स है है ना विद इन द टाइम
स्पैन आपको काम करना है सो वैल्यूड मोर ऑन हाउ क्विकली और हाउ प्रिडिक्टिबिलिटी इट कैन रेस्पों विदाउट बफर डि एंड समथिंग सो
आईडिया यह नहीं कि आपने कितना सारा काम किया यह वो वाला आईडिया नहीं है कितनी जल्दी आप रिस्पांस कर सकते हैं यह एजेंडा
होता है किसका रियल टाइम का बाकी ये सब अगेन एग्जांपल्स यहां पर लिखे हैं इसकी फर्द कैटेगरी इजेशन है कौन-कौन सा हार्ड
रियल टाइम एंड सॉफ्ट रियल टाइम ना व्हाट इज दैट हार्ड रियल टाइम एज यू कैन सी एकदम फिक्स्ड टाइम कांस्टेंट है दिस इज द
डेडलाइन यहां तक आप करेंगे मेरे लिए यूजफुलनेस मैक्सिमम है जैसे ही आप ये डेडलाइन क्रॉस करेंगे मेरे लिए आप आपकी
यूज बिलिटी इवन जीरो क्या माइनस में चली गई तो उसके बाद करोगे तो फिर कोई मतलब है नहीं है ना तो ये होता है हार्ड रियल टाइम
बिल्कुल भी हल्का सा भी मैनेज नहीं कर सकते एक बहुत अच्छा एग्जांपल है कार के अंदर एयर बैग है तो कार चल रही है
एक्सीडेंट होता है विद इन फ्रैक्शन ऑफ सेकंड एयर बैग यू नो फूलना चाहिए ताकि आपको चोट ना लगे अब एयर बैग उस समय तो
खुला नहीं आपका फेस जाके स्टेरिंग प लगा उसके दो मिनट के बाद फिर जोर से फुला वो तो उल्टा आपका सिर पीछे जाके और लगा अब तो
नुकसान कर देगा सो इन दिस काइंड ऑफ सिनेरियो आप आपको स्ट्रिक्टली डेडलाइन से पहले काम करना ही है यहां पे कोई फजी नेस
कोई मैनेज नहीं कर पाएंगे चीजों को वाइल ऑन द कांट्रेरी हमारे पास है सॉफ्ट रियल टाइम सिस्टम्स यहां पर आप देख सकते हैं
क्या है नाउ दैट इज द डेडलाइन डेडलाइन तक करें तो बहुत अच्छा बट अगर डेडलाइन क्रॉस भी होती है तो मैं नहीं बोल रहा कि यूज
बिलिटी ड्रॉप्स डाउन टू ज़ीरो इमीडिएट इट ड्रॉप डाउन टू ज़ीरो बट ग्रैजुअली इट गोज डाउन टू ज़ीरो जैसे अगेन वर्चुअल एनिमेशन
है यू नो गेम्स है ऑनलाइन गेम्स है उस तरह के केस में हम बोल सकते हैं कि दीज आर द एग्जांपल्स ऑफ सॉफ्ट रियल टाइम सिस्टम्स
जहां पे ये अच्छा बात तो नहीं होगा बट हां धीरे-धीरे धीरे-धीरे यह जीरो पे जाता है इसकी यूज बिलिटी अब गेम है ना थोड़ा लैग
हो सकता है ना थोड़ा लैग हो सकता है कोई कोई मर तो नहीं रहा ना वो वाला आईडिया है मैंने फिर भी क्या किया रियल टाइम वाले
आईडिया को डिफरेंशिएबल टाइम एंड सॉफ्ट रियल टाइम आई विल गो वन
बाय वन सो डेडलाइन मस्ट मीट स्ट्रिक्ट डेडलाइंस विदाउट फेल तो यहां बड़ा स्ट्रिक्ट है कैन मिस डेडलाइंस ओकेज
विदाउट फेलियर फिक्स्ड एंड गारंटीड रिस्पांस चाहिए ही चाहिए भाई प्रिडिक्टेबल बट नॉट गारंटीड मिल जाएगा गेम है अभी बटन
दबाओ के गोली चलेगी थोड़ा बहुत लैग हो सकता है यूज इन लाइव क्रिटिकल सिस्टम्स लाइक मेडिकल डिवाइस न्यूक्लियर रिएक्टर
जहां किसी की जान खतरे में लगी हो यूज इन मल्टीमीडिया यूजर इंटरफेस एक्सेट्रा टिपिकली मोर
कॉम्प्लेक्शन एंड यूजुअली लेस एक्सपेंसिव 100% मस्ट बी हाईली रिलायबल एंड फॉल्ट टोलरेंट रन टाइम प कोई गड़बड़ होनी नहीं
चाहिए होगा भी तो कैसे उसे मैनेज करना आपको पहले पता हो हाई हाई रिलायबिलिटी डिजायर्ड बट सम फेलर्स आर टॉलरेबल गेमिंग
की बात करो इन सब की बात करर वैसे ही नाम के आगे सॉफ्ट लगा दिया तो थोड़ा बहुत मैनेज किया जा सकता है इन दिस अप्रोच नाउ
कमिंग टू द लास्ट पॉइंट डिस्ट्रीब्यूटर ओस हम क्या कर रहे हैं वरायटी कर रहे हैं इससे पहले हमने क्या किया था इवोल्यूशन
बैच है यास पूलिंग है इवॉल्व हमने समय के साथ कैसे किया यहां पर हम वैरायटी देख रहे हैं डिस्ट्रीब्यूटर सा शब्दों में बोलूं
तो पॉइंट क्या है अगर बहुत सारे कंप्यूटर हैं फिजिकली अलग-अलग लोकेशंस पे उठा के मैंने उसको एक नेटवर्क के अंदर कनेक्ट कर
दिया दैट इज नोन एज डिस्ट्रीब्यूटर ओएस अब उसको जो मैनेज करेगा दैट इज डिस्ट्रीब्यूटर ऑपरेटिंग सिस्टम भले ही
फिजिकली दे आर अपार्ट तो दे आर एक्चुअली इंडिपेंडेंट सिस्टम्स बिल्कुल अलग-अलग है इन आपस में कोई लेना देना नहीं है बट दे
आर बाइंडेड टुगेदर बाय ए नेटवर्क तो अगेन बहुत सारे एडवांटेज मिलेंगे देखते हैं सो डिस्ट्रीब्यूटर ऑपरेटिंग सिस्टम इज अ
सॉफ्टवेयर ओवर कलेक्शन ऑफ इंडिपेंडेंट नेटवर्क्ड कम्युनिकेटिंग लूजली कपल्ड नोट्स फिजिकली सेपरेट कम्युनिकेशन बिल्कुल
फिजिकली सेपरेट है अब यहां पर क्या है नोट्स कम्युनिकेट विद वन अनदर यूजिंग वो हाई स्पीड बसेस हो सकती है इंटरनेट हो
सकता है कोई भी जॉब है अब उसको व रन टाइम पे मैनेज कर सकते हैं मान लीजिए बहुत बड़ा टास्क है तो रन टाइम पे कुछ टास्क यह वाला
सिस्टम ले लेगा कुछ यह ले लेगा आपस में डिवाइड करेंगे मैनेज करेंगे क्या-क्या एडवांटेज आपको मिलेंगे रिसोर्स शेयरिंग
मैं कहता हूं जो सारे एडवांटेज यार इंटरनेट के हैं वही डिस्ट्रीब्यूटर सिस्टम के है रिसोर्स शेयरिंग हो सकता है
कंप्यूटेशन स्पीड अप मैं आज google2 भी एक डिस्ट्रीब्यूटर सिस्टम होगा देयर आर मल्टीपल सर्वर्स जो चीजों को
मैनेज कर रहे होते हैं कनि केशन होगा सो दिस इज अ बेसिक आइडिया तो यह एक और इंपॉर्टेंट फेज हमने कवर कर
लिया जहां पर जो वैरायटी है है ना मल्टी प्रोग्रामिंग टाइम शेयरिंग देन मल्टी प्रोसेसिंग देन रियल टाइम एंड देन जस्ट
डिस्ट्रीब्यूटर कोई भी क्वेश्चन आ जाए पांच नंबर में 10 नंबर में ठोक के आ सकते हो हर चीज के जो टेबल वाले डिफरेंस है
इंपॉर्टेंट आइडियाज है सब कुछ कवर करके चल रहा है उसके आगे और कुछ देखने की जरूरत पड़ेगी नहीं यस आगे बढ़ अभी बात करते हैं
स्ट्रक्चर ऑफ ऑपरेटिंग सिस्टम की तो यह भी एक छोटा सा टॉपिक है कभी-कभार यहां से मैंने देखा है कि क्वेश्चन पूछ लिया जाता
है तो जानते हैं आईडिया क्या है देखिए सबसे पहले तो एक बात समझते हैं कि जो मोस्ट कॉमन अप्रोच है इन जनरल किसी भी
सॉफ्टवेयर को मैनेज करने की जैसे हम सॉफ्टवेयर इंजरिंग पढ़ते हैं ना कि देयर शुड बी अ मॉड्यूलर आर्किटेक्चर बहुत सारे
मॉड्यूस होने चाहिए है ना मॉड्यूस काइंड ऑफ इंडिपेंडेंट हो कपलिंग कोहेजिया एंड देन राद देन हैव अ वन मोनोलिथिक
सिस्टम मान ली एक सिंगल सिस्टम हो दीज मॉड्यूल शुड बी वेल डिफाइंड पोर्शंस अ ऑफ सिस्टम विद केयरफुली डिजाइन इनपुट आउटपुट
एंड द फंक्शंस तो केयरफुल डिजाइनिंग हो आपस में कम्युनिकेट करें टोटली टुगेदरली दे मस्ट बिहेव एज अ सिस्टम ये एक अप्रोच
है हालांकि जब हम ऑपरेटिंग सिस्टम की बात करते हैं तो एक हम बोलते हैं सिंपल स्ट्रक्चर एक सेकंड अप्रोच जो हम बोलते
हैं लेयर्ड अप्रोच तो सिंपल स्ट्रक्चर की जब बात करते हैं ना तो आईडिया कि स्टार्टिंग में जितने भी ऑपरेटिंग सिस्टम
धीरे-धीरे समय के साथ डेवलप हुए हमने कोई बहुत स्पेसिफिक बहुत स्पेसिफिक एक्सक्यूज मी लेयर्ड अप्रोच या मॉड्यूलर अप्रोच यूज
नहीं की हमने तो आईडिया क्या था मेनी ऑपरेटिंग सिस्टम डू नॉट हैव वेल डिफाइंड स्ट्रक्चर्स फ्रीक्वेंसी
जाएंगे और स्ट्रक्चर बाजी में इतना ध्यान दिया नहीं बट धीरे-धीरे फंक्शनैलिटीज एडिट होती गई काम करते गए पूरा सिस्टम एक तरीके
से हमने री कन्फर नहीं किया हम बोलते हैं सिंपल स्ट्रक्चर जैसे एक एग्जांपल है तो यहां कोई अलग-अलग ऐसा नहीं है प्रोसेस
मैनेजमेंट का अलग मॉड्यूल है मेमोरी मैनेजमेंट का अलग है कोई अलग और आपस में कम्युनिकेट कर रहे हैं देयर आर सर्टेन
लेवल्स डायग्राम इंपॉर्टेंट है याद करके बना के आएंगे तो अलग लेवल का अटेंशन आपको मिलेगा सबसे ऊपर आपको दिख रहा है
एप्लीकेशन प्रोग्राम वो कम्युनिकेट करेगा रेजिडेंट सिस्टम प्रोग्राम मान लीजिए ऑपरेटिंग सिस्टम से देन यू हैव एमएस डस
डिवाइस ड्राइवर्स तो ऑपरेटिंग सिस्टम के अपने डिवाइस ड्राइवर हैं देन रम बायोस डिवाइस ड्राइवर अभी रो के अपने ड्राइवर्स
हैं एंड देन फाइनली इन द लास्ट लेवल यू विल हैव द हार्डवेयर बट मजे की बात क्या है इफ यू हैव सम अंडरस्टैंडिंग यू नो बहुत
डिफाइंड स्ट्रक्चर नहीं है बिकॉज़ एप्लीकेशन प्रोग्राम भी अगर चाहे तो डायरेक्ट डिवाइस ड्राइवर को एक्सेस कर
सकता है बट जैसा मैं बोल रहा हूं उस समय हमारी अंडरस्टैंडिंग नहीं थी इतनी तो इस तरह का मिक्स्ड अप्रोच हमने यूज़ किया हां
अगर मैं थियोरेटिकली बात करूं इस लेयर्ड अप्रोच की तो यहां पर क्या है लेयर नंबर ज़ीरो इज़ द हार्डवेयर लेयर नंबर वन इज़ द
फिजिकल लेयर तो पूरे सॉफ्टवेयर को हम लेयर बाय लेयर डिवाइड करेंगे मान लीजिए मैं किसी भी लेयर x में हूं है ना तो जो मेरे
ऊपर लेयर है x + 1 उसको मैं सर्विस दूंगा और जो मेरे नीचे है लेयर x - 1 उससे मैं सर्विस लूंगा तो हार्डवेयर किसी लेयर को
सर्विस देंगे देन उसके ऊपर उसके ऊपर डिजाइनिंग में तीन-चार बातों का खस ख्याल रखना है आप किसी भी फंक्शन को उस लेयर में
ही लिख सकते हैं जिसका जो बेसिक रिक्वायरमेंट है उससे नीचे वाली लेयर में काम हो चुका हो इजंस पल अगर किसी को
मेमोरी यूज़ करना है तो मेमोरी रिलेटेड फंक्शन उसके नीचे ऑलरेडी अंपलिंग चाहिए एडवांटेज क्या मिलेगा कल को मेरे को लेयर
नंबर x में कोई चेंज करना है तो मेरे को सबको बताने की सारी बात बताने की जरूरत नहीं है लेयर नंबर x से कौन रिलेटेड है x
- 1 और x + 1 बस इन दोनों को अपनी बात समझाना है तो लॉन्ग रन में उसको मेंटेन करना मॉडिफाई करना स्केल करना रिलेटिवली
सब कुछ आसान होगा लेकिन थोड़ा सा स्लो यह हो जाएगा ज्यादा सिस्टमैटिक अप्रोच है तो कॉम्प्लेक्टेड वेयर सपोर्ट ऑपरेटिंग
सिस्टम कैन बी ब्रोकन इन टू पीसेज द ऑपरेटिंग सिस्टम कैन देन मेंटेन अ ग्रेटर कंट्रोल ओवर द कंप्यूटर एंड द एप्लीकेशन
प्रोग्राम सो यू शुड हैव अ फ्रीडम विद द इनर यहां पे क्या होगा फ्रीडम तो आपको मिलेगा इनर वर्किंग क्या है उसका पूरा
ध्यान डायरेक्ट रखने की जरूरत नहीं क्योंकि हमने उसको ऑलरेडी लेयर्स में डिवाइड कर दिया है अंडर दिस टॉप डाउन
अप्रोच ऑल आवर फंक्शनालिस एंड द फीचर आर डिटरमिन बाय सेपरेट कंपोनेंट्स इंफॉर्मेशन हाइडिल सो देयर हर किसी को सब बात बतानी
जरूरी नहीं है और वही जो मैंने आपसे बोला था लेयर रो से लेयर n तक पूरी फंक्शनैलिटी जा हम डिवाइड करता डिवाइड करते जाते हैं
ध्यान किस बात का रखना है फिर वही बात आपको जो चीज चाहिए एज अ इनपुट वो आपसे नीचे वाली लेयर में फुलफिल हो चुकी हो और
आप सर्विस देंगे अपने से ऊपर वाले लेयर को सो ये एक बेसिक अंडरस्टैंडिंग थी अगला आईडिया है माइक्रो कर्नल अप्रोच बहुत सारे
सेमेस्टर एग्जाम्स में इसके ऊपर मैंने क्वेश्चन देखा है व्हाट इज़ माइक्रो कर्नल अप्रोच एक कॉमन सेंस आइडिया समझाता हूं
ऑपरेटिंग सिस्टम या कर्नल एक ही बात है थोड़ा सा डिफरेंस आगे बताऊंगा फिलहाल मान लीजिए ऑपरेटिंग सिस्टम इज़ आल्सो नोन एज़
कर्नल उसका टेक्निकल नाम कर्नल है ऑपरेटिंग सिस्टम या कर्नल का साइज बहुत बड़ा है यार है ना और साइज इतना बड़ा होगा
पहले तो वह मेन मेमोरी में ज्यादा स्पेस ऑक्यूपाइड टर्म में उसको मेंटेन करना उसके अंदर मॉडिफिकेशन करना सब कुछ
कॉम्प्लेक्टेड एक अप्रोच क्या हो सकती है इसको हम बोलते हैं माइक्रो कर्नल जहां पर सिर्फ जो कर्नल के बहुत इंपॉर्टेंट
आइडियाज हैं जैसे इंटरप्रोसेस कम्युनिकेशन सिंक्रोनाइजेशन मेमोरी मैनेजमेंट सीपीयू शेड्यूलिंग जो हर बार चाहिए ही चाहिए
इसमें कोई डाउट नहीं कि ये ना चाहिए तो चाहिए ही चाहिए वो तो रहेंगे कर्नल के अंदर और लेकिन अब मैं उसे बोलूंगा माइक्रो
कर्नल बाकी एप्लीकेशन प्रोग्राम्स फाइल सिस्टम्स डिवाइस ड्राइवर्स आर देयर लेकिन वो कर्नल में नहीं रहेंगे वो उसके
बाहर रहेंगे और वह आपस में कम्युनिकेट करते रहेंगे वाया द आईडिया ऑफ कर्नल और वाया मैसेज पासिंग ओनली उससे होगा यह कि
मेरे कर्नल का साइज छोटा हो जाएगा और उसे माइक्रो कर्नल कह के बुलाऊंगा क्योंकि छोटा हो जाएगा कल को फाइल सिस्टम में कोई
चेंज करना है वो चेंज करना आसान होगा कोई अलग से यू नो एज अ कुछ अलग से मॉड्यूल ऐड करने है वो ऐड करना आसान होगा सारी चीजें
आसान हो जाएंगी आईडिया समझिए सो इन मिड 1980 रिसर्चर एर कारगी मलन यूनिवर्सिटी डेवलप ड एन ऑपरेटिंग सिस्टम कॉल्ड मैक दैट
मलाइज द कर्नल यूजिंग माइक्रो कर्नल अप्रोच अभी ये वही बोल रहा हूं दिस मेथड स्ट्रक्चर ऑपरेटिंग सिस्टम बाय रिमूविंग
ऑल नॉन एसेंशियल कंपोनेंट्स फ्रॉम द कर्नल इंप्लीमेंटिंग देम एज अ सिस्टम एज अ यूजर लेवल प्रोग्राम जैसे कोई भी एप्लीकेशन
प्रोग्राम है उसकी तरह मैं इसे डील करूंगा मैं इसको कर्नल का पार्ट नहीं मानूंगा जो इंपॉर्टेंट पार्ट बचेगा वो हो गया माइक्रो
कर्नल वन बेनिफिट ऑफ द माइक्रो कर्नल इज दैट इट मेक एक्सटें ऑपरेटिंग सिस्टम इजियर इसको चेंज करना मॉडिफाई करना आसान होगा और
यह सब आपस में डायरेक्टली कम्युनिकेट कर रहे होंगे अगर एक एग्जांपल बताएं मिनिक्स 3 माइक्रो कर्नल सिर्फ 12000 लाइन ऑफ कोड
में लिख दिया गया था पूरा ऑपरेटिंग सिस्टम 12000 लाइन ऑफ कोड में इज लाइक वेरी लेस लिखा किसने था एंड्रो स्टेन एन बम बुक भी
चलती है ऑपरेटिंग सिस्टम की बहुत अच्छी हैन नेटवर्क्स एंड ऑपरेटिंग सिस्टम अब जिसने ये सब लिखा अगर उसकी लिखी बुक से
पढ़ेंगे तो अगेन आपको एडवांटेज मिलेगा फिलहाल ये वीडियो लास्ट तक देखिएगा ओ आपका ऐसे कंप्लीट हो जाएगा सो आई थिंक माइक्रो
कर्नल अप्रोच का बेसिक आईडिया आपको क्लियर हो गया नेक्स्ट थिंग इज़ द इंटरफेस अब इंटरफेस की क्या कहानी है देखिए यह तो हम
समझ चुके हैं यूजर में और हार्डवेयर में आपस में जो इंटरेक्शन है वो ऑपरेटिंग सिस्टम कराएगा दैट वी ऑलरेडी डिस्कस इट
एक्स एज अ इंटरफेस बट आप ऑपरेटिंग सिस्टम को अपनी बात कैसे बताओगे या ओस आपको अपनी बात कैसे बताएगा इसके बारे में बात नहीं
की तो यह जो क्वेश्चन है इसको आंसर करता है इंटरफेस और यहां पे वैसे आजकल तीन बोल सकते हैं बट दो ऑप्शंस तो है ही हैं एक
हमारा है कमांड लाइन इंटरप्रेटर और सिंपली यू कैन से कमांड इंटरप्रेटर या फिर ग्राफिकल यूजर इंटरफेस तो क्या अप्रोच है
आइए एक बार देख लेते हैं प्रॉब्लम क्या समझ आ रही है ना यूजर और ऑपरेटिंग सिस्टम आपस में कैसे कम्युनिकेट करेंगे इस पे मैं
बात कर रहा हूं सो एक तो जिसे हम आम भाषा में बोल देते हैं कमांड प्रोमट या सीएमडी आप जाएंगे जो जो कमांड आपको लिखनी है जो
जो काम करना है वो कैसे पता लगेगा यू विल राइट इट एज अ पीस ऑफ़ अ कमांड आप कमांड लिखेंगे और वो कमांड रन होगा अगर मैं
थोड़ा सा डिटेल में जाऊं इसको हम बोलते हैं कमांड इंटरप्रेटर सम ऑपरेटिंग सिस्टम इंक्लूड कमांड इंटरप्रेटर एस कर्नल मतलब
कुछ लोग इसको ऑपरेटिंग सिस्टम का पार्ट मानते हैं कुछ लोग पार्ट नहीं मानते अब मैं वो बात भी पूरी कर देता हूं होता यह
है ऑपरेटिंग सिस्टम में एक हमारा हुआ इंटरफेस और एक हमारा हुआ कर्नल इन दोनों को मिला के हम बोलते हैं ऑपरेटिंग सिस्टम
कोई आपसे पूछे व्हाट इज ऑपरेटिंग सिस्टम कर्नल इज दैट पार्ट जो एक्चुअल यू नो मैनेजमेंट वाला काम कर रहा होता है इ फेस
जो कम्युनिकेशन भी हैंडल कर रहा होता है तो अगर आप इस इंटरफेस वाले पार्ट को हटा देते हैं जो बचता है दैट इज नोन एज कर्नल
फेर इनफ अदर सच एज विंडोज है यक्स है ट्रीटेड कमांड इंटरप्रेटर एज अ स्पेशल प्रोग्राम रनिंग वन अ जॉब इज
इनिशिएटिव कर रहा होगा कुछ ऑपरेटिंग सिस्टम में जैसे यक्स है लाइक्स है यहां पर आपको चॉइस भी
मिल जाती है मतलब देर आर मल्टीपल कमांड प्रॉम्स लाइक शेल बॉन शेल सी शेल बंड अगेन शेल कॉन शेल ब्ला ब्ला ब्ला मतलब वी विल
नॉट गो इन टू द डिटेल बेसिक आईडिया कमांड लिखो जो काम करना है वो काम हो जाएगा प्रॉब्लम क्या है कमांड पता किसको है कुछ
टेक्निकल लोग हो सकते हैं बट जो आम यू नो जो लेमन यूजर है जिसको ऑपरेटिंग सिस्टम इस्तेमाल करना उसको ये सब बात समझ नहीं
आती उसके लिए क्या करना पड़ेगा ग्राफिकल यूजर इंटरफेस तो यहां पर जैसा आमतौर पर आप और हम इस्तेमाल करते हैं एक जीआई हमारे
पास होता है बैकग्राउंड प कमांड ही रन करती है बट फॉर एग्जांपल आप यहां पर गए और आपने माउस के थ्रू यहां पे क्लिक किया तो
देयर विल बी अ प्रोग्राम जो कैलकुलेट करेगा माउस का जो कर्सर है उसका एक्स वा एक्सेस क्या है कैलकुलेटर है देन ऑन द बैक
एंड इट विल इनिशिएटिव ग्राफिकल यूजर इंटरफेस में करेंगे आइकंस होंगे पॉइंट्स होंगे सारी की सारी चीज
अच्छा हर स्लाइड में नोट्स मैंने प्रॉपर मेंशन किया है यू वांट टू टेक देम डाउन यू वांट टू यू नो रिमेंबर उसको याद कर लेना
चाहते हो राइट इन अ मच बेटर सेंस इन एन एग्जाम जरूर करना सो सेकंड स्ट्रेटेजी इज ऑपरेटिंग सिस्टम इज यूजर फ्रेंडली अप्रोच
है जीआई है माउस बेस्ड अप्रोच है जहां पर आपकी जो पोजीशन होगी आइकन के ऊपर आप क्लिक करेंगे पैक एंड पे वही सारे फाइल्स फंक्शन
प्रोग्राम्स कोड्स इ इन यू नो इवोक होंगे और एग्जीक्यूशन चलेगा एक और चीज अब मुझे बात जरूर कर लेनी चाहिए वो क्या है वो है
टच बिकॉज़ आजकल मोबाइल फोस की अगर बात करें ज्यादा ज्यादातर काम हम मोबाइल फोस पे ही कर रहे होते हैं हो सकता है वीडियो
मोबाइल फोन पे देख रहे हैं मैं भी वीडियो मोबाइल फोन से ही शूट कर रहा हूं तो काम मोबाइल फोन पे हो रहा है ना दे आर काइंड
ऑफ टच वाला आईडिया है ना तो आप मान सकते हैं जीआई का ही नेक्स्ट वाला लेवल है ये यहां पर बिकॉज इट इज इंप्रैक्टिकल आप ये
सब करें टच स्क्रीन होता है आप कितने यू नो फिंगर से प्रेस कर रहे हैं कितने प्रेशर से प्रेस कर रहे हैं क्या आपका
जेस्चर है है ना मल्टी टच और वो सारी चीजें आजकल स्मार्टफोंस के अंदर रहती है सो दिस इज आल्सो अप्रोच जिसके थ्रू आप
बताना चाह रहे हो थे कि को क्या काम करना है फेयर एनफ अब आईडिया ये है कि बेटर क्या है देखिए ये एक सब्जेक्टिव बात है अगर कोई
बहुत ज्यादा टेक्निकल यूजर है जिसको अंडरस्टैंडिंग है ऑपरेटिंग सिस्टम के ऊपर ज्यादा कंट्रोल ले सकता है वो कमांड लाइन
यूज कर सकता है बट इन जनरल आइ मोर देन 95 96 पर ऑफ द टाइम और इवन मोर जो आम आदमी है जिसको इस्तेमाल करना है ऑपरेटिंग सिस्टम
लिखना नहीं है उ ऑपरेटिंग सिस्टम का इस्तेमाल करना है किसी एप्लीकेशन प्रोग्राम को यूज करना है उसके लिए
ग्राफिकल यूजर इंटरफेस ही बट बटर रहता है है ना तो दोनों के अपने अलग-अलग फायदे अपने अलग-अलग नुकसान है सारे पॉइंट्स
मैंने यहां पे क्लियर कट मेंशन करके रखे हैं नेक्स्ट आईडिया आ जाता है सिस्टम कॉल अगेन वेरी वेरी इंपॉर्टेंट व्हाट इज
सिस्टम कॉल देखिए पहले आसान भाषा में समझाता हूं ये तो मैं मैं पहले आपको समझा चुका हूं ना कि जो हार्डवेयर है हार्डवेयर
के ऊपर सिर्फ और सिर्फ कंट्रोल है कर्नल का है ना अब अगर कोई यूजर लेवल प्रोग्राम है उसको हार्डवेयर के ऊपर कुछ काम करना है
मान लीजिए प्रिंट करना है अब प्रिंट कैसे करेगा ऑपरेटिंग सिस्टम कहता है कि यार मैं किसी को कुछ करने ही नहीं दूंगा तो हम
क्या कहते हैं य ऑपरेटिंग सिस्टम क्या कहता है दैट दे इज एन आइडिया ऑफ यूजिंग अ सिस्टम कॉल आप एज अ यूजर एज अ यूजर लेवल
प्रोग्राम आप ऑपरेटिंग सिस्टम कर्नल के पास आएंगे और आप बोलेंगे टिंग टिंग टिंग नॉक नॉक कर्नल बोलेगा क्या है बोलो मेरे
को प्रिंट करना है इसको बोलते हैं सिस्टम कॉल करना सिस्टम को बुलाना तो कर्नल या ओएस क्या बोलेगा कोई बात नहीं तुम्हारे
बिहाव पे मैं प्रिंट करने वाला हूं यह पूरा आईडिया कहलाता है सिस्टम कॉल इससे आसान तरीके से इस बात को नहीं समझा जा
सकता सता है यस तो ऑपरेटिंग सिस्टम ऐसी बहुत सारी फंक्शनैलिटीज है वह ऐसा नहीं कह रहा मैं काम करने ही नहीं दूंगा वो कह रहा
है बस आपके बिहाव पे काम मैं करूंगा क्या काम करूंगा उसकी पूरी लिस्ट वो पहले से बना के रखता है कि यह सारे काम है जो मैं
कर सकता हूं ऑन योर बिहाव जब भी आपको जरूरत पड़े नॉक नॉक करो मेरे को बताओ आई विल डू दैट वर्क ऑन योर बिहाव दैट इज
कॉल्ड सिस्टम कॉल सो आई विल गो वन बाय वन सिस्टम कॉल प्रोवाइड्स अ मीन फॉर अ यूजर प्रोग्राम टू आस्क ऑपरेटिंग सिस्टम टू
परफॉर्म अ टास्क रिजर्व फॉर ऑपरेटिंग सिस्टम ऑन द यूजर प्रोग्राम्स बिहा थोड़ा अच्छा इंग्लिश हो गया बट बहुत अच्छा पॉइंट
लिखा हुआ है यूज़र प्रोग्राम अ सिस्टम कॉल क्या है एक मैकेनिज्म प्रोवाइड करता है यूज़र प्रोग्राम को कि आप ऑपरेटिंग सिस्टम
से बोलो कि वह टास्क परफॉर्म करे ऑन द बिहा ऑफ़ यूज़र प्रोग्राम इट प्रोवाइड एन इंटरफेस टू द सर्विसेस मेड अवेलेबल बाय दन
ऑपरेटिंग सिस्टम आमतौर पे जो सिस्टम कॉल है ससी प्लस में लिखे होते हैं अलग-अलग एपीआई हैं मैं आपको एग्जांपल से दिखाता
हूं जैसे एक बहुत अच्छा एग्जांपल देखिए इस इमेज से आपको समझ आएगा सी में ने कोड लिखा और बोला प्रिंट कराना है ग्रीटिंग्स अब
प्रिंट एफ का क्या मतलब है ये ओएस को नहीं पता है यह पता है आपका जो यू नो कंपाइलर है उसको तो ये बात आपके कंपाइलर ने समझी
स्टैंडर्ड लाइब्रेरी ने और अब वो गया किसके पास ओएस के पास कि हमको ना ग्रीटिंग प्रिंट कराना है तो ओस के पास एक सिंगल
फंक्शन है मे बी राइट वो राइट फंक्शन के थ्रू जाएगा इस्तेमाल करेगा और आपके बि हाफ पे स्क्रीन के ऊपर ग्रीटिंग्स प्रिंट करा
देगा अब वो कोड सी में लिखा हो पाइथन में लिखा हो में लिखा हो c+ प् में लिखा किसी लैंग्वेज में हो चार अलग-अलग कोड हो सकते
हैं बट ओस हर बार किसको इवोक करेगा राइट को इवोक करेगा यहां एक पूरी डायरेक्टरी देखिए मैंने बना के रखी आमतौर पे कौन-कौन
से रटना नहीं है बट स्टिल आपको पता होना चाहिए जैसे प्रोसेस कंट्रोल है दीज आर सम ऑफ द जनरल यू नो सिस्टम कॉल्स एंड करना है
अड करना है लोड करना है एग्जीक्यूट करना है कोई प्रोसेस क्रिएट करना है टर्मिनेट करना है इन सबके लिए सिस्टम कॉल्स अवेलेबल
होते हैं फाइल मैनेज फाइल से गार्डिंग जो जो सिस्टम कॉल है यहां मैंने लिख के रखे हैं डिवाइस मैनेजमेंट के जो जो स्टैंडर्ड
सिस्टम कॉल्स है रिटन देयर इंफॉर्मेशन मेंटेनेंस गेट प्रोसेस फाइल डिवाइस के ट्रीबो सब सिस्टम कॉल के थ्रू होता है
कम्युनिकेशन कोई कम्युनिकेशन कनेक्शन नेटवर्क्स का जितना काम है वो कम्युनिकेशन प्रोटोकॉल्स के थ्रू होता है दिस इज द
आईडिया तो आई होप सिस्टम कॉल की पूरी कहानी आपको समझ आ गई होगी हम किस तरह से यहां पर काम करते हैं और हर ऑपरेटिंग
सिस्टम का आपने सुना होगा एपीआई होता है एप्लीकेशन प्रोग्राम इंटरफेस जो आप प्रोग्रामर कर देते और प्रोग्राम इसको कॉल
करता है एक और बात बोल देता हूं टू वे एब्स्ट्रेक्शन राइट को नहीं पता उसको इस बात से नहीं लेना देना जिसने ऑपरेटिंग
सिस्टम लिखा है कि राइट को कौन कॉल कर रहा है सी का कोड कर रहा है c+ प का कर रहा है जावा पाइथन अपने को क्या लेना देना है जब
हम प्रोग्राम लिखते हैं सी के कंपाइलर को कोई लेना देना नहीं है कि वो एगजैक्टली एग्जीक्यूट कैसे होता है इजेंट इट
प्रोग्रामर का काम होना चाहिए आप अपना कोड लिखो एक सिंगल फंक्शन होगा जिसके थ्रू उसको एग्जीक्यूट करा देंगे सो आई थिंक
सिस्टम कॉल पूरी कहानी समझ आ गई अच्छे से आप लिख के आओगे मोड क्या होता है सिस्टम कॉल में ही इंटीग्रेटेड पार्ट है इसको ऐसे
समझिए कोई हम सिस्टम दो तरह से काम करता है कभी-कभी तो यूजर का कोड चल रहा होगा जैसे सिस्टम कॉल होगा मैं आपको क्या बोल
रहा हूं ऑपरेटिंग सिस्टम सारी चीजें अपने हाथ में ले लेता है और कहता है मैं मैनेज करूंगा इसी को हम बोलते हैं यूजर मोड
कर्नल मोड यूजर मोड कर्नल मोड कोई प्रोसेस चल रहा था अचानक यूजर ने बोला मेरे को ये काम करना है वाया सिस्टम कॉल तो यहां
सिस्टम यूजर मोड से कर्नल मोड में आ गया इजंस सिस्टम को जो काम करना था किया उसने फिर से दोबारा कंट्रोल किसको दे दिया यूजर
को दे दिया दिस इज द आईडिया तो आमतौर पे एक बिट होती है जि हम बोलते हैं मोड बिट क्या बोलते हैं मड बिट तो मड बिट की
वैल्यू इन जनरल अगर ज़ीरो होती है तो मानते हैं सिस्टम यूजर मोड में है यानी कि अभी यूजर प्रोग्राम रन कर रहा है और अगर
कर्नल मोड बिट की वैल्यू जीरो होती है उसको बोलते हैं कर्नल मोड इस बात का मतलब मतलब क्या हो गया कि फिलहाल जो टोटल
एग्जीक्यूशन है वो कर्नल के हाथ में हालांकि मैं बता दूं दिस इज नॉट लाइक वेरी वेरी स्टैंडर्ड थिंग कुछ सिस्टम में उल्टा
भी हो सकता है कि मान लीजिए वो कह रहा है नहीं मेरे हिसाब से जीरो का मतलब यूजर मोड है वन का मतलब कर्नल है हो सकता है आमतौर
पे यूजर को वन और कर्नल को जीरो दिया जाता है है ना तो मोड बिट की बात आप समझ गए एक छोटा सा एग्जांपल मैंने समझाने की कोशिश
की हम मान लीजिए अंबानी है अपने घर के अंदर बैठे उनका प्राइवेट स्पेस है उनकी सिक्योरिटी प्राइवेटली मैनेज कर सकते हैं
अपने ऑफिस में बैठे उनका अगेन प्राइवेट स्पेस है अपनी सिक्योरिटी अपने लेवल पर मैनेज करेंगे लेकिन अंबानी को रोड से होते
हुए ऑफिस जाना और ऑफिस से आना है वापस अब रोड पे अंबानी को चाहिए सिक्योरिटी है ना अब सिक्योरिटी के लिए क्या गवर्नमेंट अलाव
करेगी अंबानी को कि यार तुम अपनी बंदूकें रख लो रिस्की है इजेंट इट तो अब यहां पर ऑपरेटिंग सिस्टम कौन है गवर्नमेंट ऑफ
इंडिया गवर्नमेंट ऑफ इंडिया की रिस्पांसिबिलिटी है सिटीजन को सिक्योरिटी दे और अगर सिटीजन इंपॉर्टेंट है जो इतना
टैक्स पे करता है जो इतनी बड़ी इंडस्ट्रीज अन कर रहा है उसको एडिशनल सिक्योरिटी दे तो यहां पर मैं बोल रहा हूं सिस्टम आ गया
कर्नल मोड के अंदर सिस्टम बोल रहा है सिक्योरिटी ये जो सिक्योरिटी है पर्सनल सिक्योरिटी नहीं है ये सीआईएसएफ का जवाना
है भारत सरकार की सिक्योरिटी है तो इसने कॉल किया सिस्टम कॉल को मेरे को सिक्योरिटी दो हमने कहा आप बंदूक मत लो हम
आपको सिक्योरिटी देते हैं एज अ गवर्नमेंट ऑफ इंडिया उसके बदले में टैक्स लेंगे आपसे ये आपको सिक्योरिटी द जब आप ऑफिस गए तो
फिर से आप टेंशन फ्री होके काम कर सकते हो एक छोटा सा एनालॉजिक करने की कोशिश की है तो आई होप और अच्छे से आपको य बात समझ आई
होगी तो चलिए अभी बात करेंगे प्रोसेस मैनेजमेंट के बारे में और सबसे पहले जानना पड़ेगा प्रोसेस क्या है प्रोसेस का जब
डिस्कशन स्टार्ट करते हैं तो एक जो बड़ा कॉमन यू नो आईडिया कई बार सेमेस्टर से पूछा जाता है प्रोग्राम क्या है प्रोसेस
क्या है कोई प्रोग्राम प्रोसेस कब बनता है तो उस सारी अंडरस्टैंडिंग को एक-एक करके जानना शुरू करते हैं सो टॉकिंग अबाउट
प्रोसेस आज इन जनरल अ प्रोसेस इज अ प्रोग्राम इन एग्जीक्यूशन कोई प्रोग्राम है रिटन प्रोग्राम हमारे पास लिखा हुआ है
और बोल ये रहे हैं कि जैसे ही वो प्रोग्राम एग्जीक्यूट होना स्टार्ट हो जाता है दैट बिकम अ प्रोसेस पर थोड़ी और
टेक्निकल है मैंने सारे पॉइंट्स मेंशन किए वी विल गो वन बाय वन सो अ प्रोग्राम इज़ नॉट अ प्रोसेस बाय डिफॉल्ट प्रोग्राम इज़
अ पैसिव एंटिटी दैट इज़ अ फाइल कंटेन ऑफ़ इंस्ट्रक्शन स्टोर्ड ऑन अ डिस्क एंड ऑफर इज़ आल्सो कॉल्ड एज़ एग्जीक्यूटेबल फाइल
एक कोड हमारे पास लिखा हुआ है डिस्क में स्टोर है फिलहाल वह प्रोग्राम है व प्रोसेस नहीं है एग्जीक्यूटेबल है यानी कि
एग्जीक्यूट होने की कैपेसिटी रखता है जब वह प्रोग्राम एग्जीक्यूट होना स्टार्ट हो जाएगा तब वो प्रोसेस बन जाएगा बट अभी वो
प्रोग्राम ही है आगे प्रोग्राम बिकम अ प्रोसेस व्हेन एन एग्जीक्यूटेबल फाइल इज लोडेड इन टू मेन मेमोरी एंड व्हेन इट हैज
पीसीबी इज क्रिएटेड्रॉअर्नेविगेटर वो एक प्रोग्राम था अब अगर ऑपरेटिंग सिस्टम वैसे ऐसा भी हो सकता है ऑपरेटिंग
सिस्टम अलाउ ना करें कि अभी हम कुछ और इंपॉर्टेंट काम कर रहे हैं या फिलहाल ये पॉसिबल नहीं है बट अगर ओस अलाउ करता है जो
कि ज्यादातर केस में करेगा तो सबसे पहले क्या करता है ऑपरेटिंग सिस्टम एक डाटा स्ट्रक्चर क्रिएट करता है जिसको बोलते हैं
पीसीबी पीसीबी स्टैंड फॉर प्रोसेस कंट्रोल ब्लॉक कुछ इस तरह का एक डाटा स्ट्रक्चर मोटे शब्दों में बोलूं तो किसी प्रोसेस से
संबंधित जो भी इंफॉर्मेशन जो भी मेटा डाटा लेखा जोखा जो भी है ना वो सब इसके अंदर स्टोर रहता है प्रोसेस अभी आगे बात करेंगे
प्रोसेस कौन से स्टेट में है एक यूनिक प्रोसेस नंबर एक यूनिक प्रोसेस आईडी उसको दी जाती है अगर कुछ काउंटर्स है रजिस्टर्स
की वैल्यू कितनी फाइल्स उसके पास है मेमोरी लिमिट सारा का सारा इंफॉर्मेशन पीसीबी में रहेगा तो पीसीबी एक पहचान है
मान लीजिए ये प्रोसेस का आधार कार्ड है जैसा आपका और मेरा आधार कार्ड है ना ऐसा प्रोसेस का भी आधार कार्ड है तो जैसे ही
प्रोसेस का पीसीबी बना मान लो प्रोसेस बन गया प्रोसेस है तो पीसीबी है प्रोसेस नहीं है तो पीसीबी नहीं है इनके बीच में रहेगा
वन टू वन मैप तो ये कहानी है पीसीबी की तो बोल रहा हूं प्रोग्राम प्रोसेस कब बन जाता है अगर ऑपरेटिंग सिस्टम ने आपके रिक्वेस्ट
एंटरटेन करी और वो क्रिएट कर दिया पसी भी मान लेते हैं प्रोसेस बन गया अ प्रोसेस ऑन द अदर हैंड इज एन एक्टिव एंटिटी प्रोसेस
को तो चीजें चाहिए प्रोग्राम की तरह ऐसे नहीं स्टोर करके सोया हुआ है तो उसको सीपीयू टाइम चाहिए मेमोरी चाहिए रजिस्टर
चाहिए सिस्टम बसेस चाहिए तो ये भी एक पॉइंट होता है उसको बोलते हैं पैसिव उसको बोलते हैं एक्टिव गोइंग विद द फ्लो आगे
देखेंगे इफ टू प्रोसेस ये बड़ा इंपोर्टेंट पॉइंट है इफ टू टू प्रोसेस मे बी एसोसिएटेड विद द सेम प्रोग्राम दे आर ल्स
स्टिल कंसीडर्ड एज सेपरेट एग्जीक्यूशन सीक्वेंस कहना ये चाह रहा हूं मान लीजिए एक सिंगल प्रोग्राम लिखा हुआ है अब ऐसा हो
सकता है ना एक ही प्रोग्राम दो बार एग्जीक्यूट करूं तो एक बार एग्जीक्यूट करूंगा फॉर एग्जांपल इट विल बिकम प्रोसेस
वन एक और बार एग्जीक्यूट करूंगा तो ऐसा नहीं है सेम प्रोसेस है दोनों अलग-अलग प्रोसेस है दोनों का एक दूसरे से कोई लेना
देना नहीं है तो प्रोग्राम एक प्रोग्राम के साथ मल्टीपल प्रोसेस हो सकती हैं बट ऐसा नहीं हो सकता कि एक प्रोसेस मल्टीपल
प्रोग्राम के साथ एसोसिएटेड हो इजन इट वेरी बेसिक अंडरस्टैंडिंग अच्छा अगर बात करें प्रोसेस की मेमोरी के हिसाब से
सिस्टम में क्या-क्या चीजें हैं तो कुछ इस तरह से प्रोसेस आपको नजर आएगी मेमोरी के अंदर जो उसका इमेज होगा जिसमें आप देख रहे
हैं हमारे पास टैक है हीप है डाटा है एंड टेक्स्ट है बहुत शॉर्ट में आईडिया यू नो डिस्कस कर रहा हूं सबसे पहले टेस्ट
टेक्स्ट सेक्शन है हमारा यहां पर क्या है जो भी कोड है है ना प्रोग्राम जिसको हम एग्जीक्यूट कर रहे हैं वो आपको कहां
मिलेगा टेक्स्ट सेक्शन में मिलेगा नेक्स्ट स्टैक व्हिच कंटेन टेंपररी डाटा फंक्शन है यू नो जो भी एक्टिवेशन रिकॉर्ड भी जिसे
आमतौर पे बोलते हैं वो तो स्टैक में मैनेज होता है और ये ऊपर से नीचे इसलिए चलता है ताकि मेमोरी को अच्छे से हैंडल किया जा
सके सारा स्पेस यूटिलाइज होने के बाद ही ये काम करें तो स्टैक ओवरफ्लो आपने सुना भी होगा क्यों होता है अगर आप रिकर्स
वगैरह में चले गए सारा स्पेस कंज्यूम हो गया तो इसी को बोलते हैं स्टैक ओवरफ्लो होना तो सारा एक्टिवेशन रिकॉर्ड यहां पर
रहेगा अ डेटा सेक्शन में जितना भी हमारा ग्लोबल डाटा ग्लोबल वेरिएबल है वो डेटा सेक्शन में रहेगा एंड लास्ट इज द हीप
जो भी मेमोरी एलोकेशन होता है डायनेमिक एलोकेशन जो हम कर सकते हैं यूजिंग हीप्स वो सब यहां पर होता है तो एक बेसिक इमेज
है प्रोसेस की ये चार पॉइंट याद रखेंगे डायग्राम बना के आएंगे मामला एकदम सेट हो जाएगा अगेन यहां पर मैंने फर्द वैसे मुझे
लगता है सफिशिएंट मैंने एक्सप्लेन किया है बट स्टिल फॉर यू प्रोग्राम और प्रोसेस में पूरा पांच-छह पॉइंट का डिफरेंस बना है
इसको एग्जाम में पेल के आ जाओगे कहानी खत्म मैं साइड हो जाता हूं यू कैन टेक अ स्क्रीनशॉट प्लीज यूज दिस है ना आईडिया
मैंने ऑलरेडी कवर किया पीसीबी की एक बार और डिटेल में बात कर देता हूं हालांकि मैं आईडी आपसे डिस्कस कर चुका हूं तो पीसीबी
क्या है पूरे प्रोसेस का जो भी मेटा डाटा है वो एक डाटा स्ट्रक्चर में स्टोर करते हैं उसको बोलते हैं पीसीबी पीसीबी स्टैंड
फॉर प्रोसेस कंट्रोल ब्लॉक ये जो डायग्राम मैं आपको यहां पर दिखा भी रहा हूं ना ये भी एक एप्रोक्सीमेशन है क्योंकि ऑपरेटिंग
सिस्टम टू ऑपरेटिंग सिस्टम चीजें डिफर कर सकती है तो कोई बोल सकता है मुझे इसमें थोड़ा और डटा चाहिए कोई बोल सकता है मुझे
कम चाहिए वो उसका क्या नाम रखे अलग-अलग बातें हैं बट आमतौर पे प्रोसेस कौन से स्टेट में है
प्रोग्राम काउंटर प्रोसेस में भी यू नो एग्जीक्यूट होते हुए कांटेक्ट स्विच हुआ अगली बार जब रन करेगा तो कौन सा
इंस्ट्रक्शन रन करेंगे वो सारी बात सीपीयू के रजिस्टर जितने भी रजिस्टर्स हैं इंस्ट्रक्शन रजिस्टर डेटा रजिस्टर जितने
भी सेपरेट रजिस्टर हो सकते हैं जिस समय कांटेक्ट स्विच हुआ उन सबकी क्या-क्या वैल्यूज थी वो सब ये सेव करके रखेगा
अपार्ट फ्रॉम दैट सीपीयू की शेड्यूलिंग इंफॉर्मेशन है मेमोरी मैनेजमेंट अकाउंटिंग इनपुट आउटपुट मैं बोल रहा हूं ना प्रोसेस
का जो इमेज है उसके अलावा उसका जितना भी इंफॉर्मेशन जितना मेटा डाटा वो सब का सब आपको उसके
पीसीबी में मिलने वाला है तो यह बात याद रखेंगे भूलेंगे नहीं गोइंग विद द फ्लो नेक्स्ट थिंग इज प्रोसेस साइकिल जैसे एक
ह्यूमन है उसकी एक लाइफ साइकिल होती है गोइंग इन डिफरेंट डिफरेंट स्टेजेस सिमिलरली जो प्रोसेस है वो भी अपनी पूरी
लाइफ में पूरे एग्जीक्यूशन में मल्टीपल स्टेट से होके गुजरता है और यह बहुत इंपॉर्टेंट टॉपिक है शायद ही ऐसा कोई पेपर
आपको मिले जिसमें एक बार प्रोसेस स्टेट्स के बारे में बात ना की गई हो तो ध्यान से समझिए देखिए जैसे ही कोई नया प्रोसेस आता
है मान लीजिए एक नया प्रोसेस पैदा हुआ उसको बोलते हैं कि अभी प्रोसेस न्यू स्टेट में है कौन स स्टेट में न्यू स्टेट में
न्यू प्रोसेस है अब यहां पर हम बोल रहे हैं प्रोसेस न्यू स्टेट से माइग्रेट करता है किसमें रेडी स्टेट में रेडी स्टेट क्या
होता है वो स्टेट जिसमें हम बोलते हैं कि अब प्रोसेस एग्जीक्यूशन के लिए रेडी उसको बोलते हैं रेडी स्टेट इस बात को समझिए
एग्जीक्यूशन के लिए रेडी होना और नहीं होने में क्या डिफरेंस है क्या ऐसा हो सकता है कि कोई प्रोसेस हमारे पास हो
प्रोसेस क्रिएट है बट अभी फिलहाल वो सीपीयू पे एग्जीक्यूट नहीं करना चाह रहा हो सकता है मान लीजिए एक अलार्म है फोन के
अंदर अलार्म हमने लगा दिया तो क्या उसको सीपीयू चाहिए नहीं जब टाइम आएगा तब उसको जाके रिंग करना है इजेंट इट तो देयर कुड
बी मल्टीपल सिनेरियो मल्टीपल थिंग्स जिसके लिए वो वेट कर रहा हो बट अभी वो एग्जीक्यूट नहीं करना चाह रहा जैसे ही कोई
एग्जीक्यूट करना चाहेगा तब वो न्यू से आ जाएगा कहां पे रेडी के अंदर एक और बात समझिए डायरेक्ट रनिंग में क्यों नहीं गया
सीपीयू पे क्यों नहीं गया भाई एक प्रोसेस नहीं है ना बहुत सारे प्रोसेस हैं तो यहां पर रेडी स्टेट में बैठ के वेट करेगा जरूरी
नहीं है ना जिस समय उसका मन करे तुरंत उसको सीपीयू मिल जाए वेट कर रहा है कुछ समय के बाद अलग-अलग सीपीयू शेड्यूलिंग
एल्गोरिथम से आगे डिस्कस करेंगे फर्स्ट कम फर्स्ट सव राउंड रॉबिन प्रायोरिटी है अलग-अलग है जैसे ही आपका नंबर आएगा आप
जाएंगे और सीपी प एग्जीक्यूट करना चालू कर देंगे तो अब आप आ गए कौन सी स्टेट में रनिंग स्टेट में अब क्या-क्या हो सकता है
अगर सब कुछ बढ़िया हो कोई प्रॉब्लम ना हो हो सकता है आप यहीं से एग्जिट कर जाए इजेंट इट कोई प्रॉब्लम नहीं यू गो टू
टर्मिनेटेड आपका पीसी भी खत्म कहानी खत्म हो सकता है बीच में आप रन करना चाह रहे हैं लेकिन रन करते-करते कोई इनपुट आउटपुट
ऑपरेशन किसी दूसरे इवेंट के लिए आपको वेट करना है अब भूलिए नहीं हम क्या पढ़ रहे हैं हम पढ़ रहे हैं मल्टी प्रोग्रामिंग और
मल्टी प्रोग्रामिंग में हमने सीखा है सीपीयू किसी के लिए वेट नहीं करेगा तो आप यहां से चले जाएंगे वेटिंग स्टेट में जो
भी इनपुट आउटपुट है जिस भी इवेंट के लिए आप वेट कर रहे हैं वह काम पूरा करेंगे और फिर दोबारा रनिंग में नहीं जाएंगे फिर
जाएंगे रेडी में क्यों क्योंकि जैसे ही आप यहां से बाहर निकले क्या सीपीयू आपके लिए सीपीयू खाली बैठा था नहीं उसने तुरंत किसी
दूसरे प्रोसेस को शेड्यूल कर लिया होगा तो मैं आपको दोबारा से भेज दूंगा रेडी में फिर जैसे नंबर आएगा फिर दोबारा आप इधर आ
जाएंगे ये हुआ एक एक बेसिक अंडरस्टैंडिंग कभी-कभी क्या हो सकता है आप रनिंग है रनिंग करना चाहते हैं और एग्जीक्यूट करना
चाहते हैं बट मे बी मान लीजिए प्रायोरिटी एल्गोरिदम है और कोई ज्यादा इंपॉर्टेंट ज्यादा प्रायोरिटी वाली प्रोसेस आ गई अब
क्या करना पड़ेगा अब आप बोलोगे मैं तो रन करना चाहता हूं मेरे को इनपुट आउटपुट नहीं करना तो आपको फोर्सफुली यहां से बाहर जाना
पड़ेगा बाद में बात करूंगा प्रिमिटिव और नॉन प्रिमिटिव दो तरह की शेड्यूलिंग होती है तो फोर्सफुली आप दोबारा जाएंगे रेडी
क्यू में बैठेंगे किसी दूसरे प्रोसेस को एग्जीक्यूट कराया जाएगा एंड देन कुछ समय के बाद अकॉर्डिंग टू द एल्गोरिथम आपको
दोबारा नंबर आ जाएगा तो ये एक बेसिक अंडरस्टैंडिंग है न्यू मै आप आते हैं रेडी मींस व्हाट व्हेन यू आर रेडी फॉर द सीपीयू
जब सीपीयू के लिए रेडी है रनिंग में चले जाएंगे यहां से या तो इनपुट आउटपुट के लिए जाएंगे या तो जबरदस्ती बाहर निकाले जाएंगे
दोनों ही काम करने के बाद आप फिर से रेडी में आएंगे देन यू गो देयर एंड देन रनिंग सेफ एवरीथिंग फाइन यू गो टू एग्जिट ये एक
बेसिक आईडिया हुआ इन द फ्लो एक प्रोग्राम्स होते हैं हमारे पास शेड्यूलर देखो मैंने ये तो आपसे बोल दिया कि पूरे
लाइफ स्पैन में प्रोसेस अलग-अलग स्टेजेस में स्विच करेंगे बताया आपको लेकिन ये डिसीजन लेगा कौन कौन स्विच कराता है तो
शेड्यूलर्स वो प्रोग्राम होते हैं जो इस बात की रिस्पांसिबिलिटी लेते हैं कि पूरे लाइफ साइकिल में अगर कोई न्यूज़ से रेडी
में आया या रेडी से रनिंग में गया कौन डिसीजन लेता है तो दीज आर कॉल्ड शेड्यूलर प्रोग्राम तो प्रोसेस माइग्रेट्स अमंग
वेरियस शेड्यूलिंग क्यूज थ्रू आउट इट्स लाइफ टाइम ऑपरेटिंग सिस्टम मस्ट सेलेक्ट फॉर शेड्यूलिंग पर्पस प्रोसेसेस फ्रॉम दीज
क्यूज एंड दिस सिलेक्शन इज़ कैरिड आउट बाय एप्रोप्रियेट हैं कितने शेड्यूलर होते हैं तीन तरह के शेड्यूलर हमारे पास हैं लॉन्ग
टर्म मिडिल टर्म एंड शॉर्ट टर्म तो पहले बात करता हूं लॉन्ग टर्म की लॉन्ग टर्म शेड्यूलर डिटरमाइंस व्हिच प्रोसेस एंटर्स
द रेडी क्यू फ्रॉम द जॉब पूल तो जो न्यू क्यूज हमारे रे पास है न्यू स्टेट था ना अब कौन आएगा एग्जीक्यूशन के लिए रेडी के
अंदर यह डिसीजन कौन लेता है तो रेडी सॉरी न्यू से रेडी में आने वाला डिसीजन कौन लेगा लॉन्ग टर्म शेड्यूलर इसे कुछ लोग
स्पुलर भी बोल देते हैं यस ऑपरेटिंग ऑपरेटिंग लेस फ्रीक्वेंसी सम गोल सच एज मैक्सिमाइजिंग थ्रू पोट अभी
आगे डिटेल में आप समझ जाओगे इसका काम है हर तरह की प्रोसेस को अंदर लेके आना और लॉन्ग रन के अंदर कितने प्रोसेस मेमोरी
में रहेंगे इस बात का ध्यान रखता है जितने प्रोसेस सिस्टम से जा रहे हैं उतने नए प्रोसेस आते रहे यह भी डिसाइड करना लॉन्ग
टर्म शेड्यूलर का ही काम है देन पहले मैं चला जाता हूं शॉर्ट टर्म का अब शॉर्ट टर्म का काम क्या है द शॉर्ट टर्म शेड्यूलर और
द सीपीयू शेड्यूलर सेलेक्ट द प्रोसेस अमंग द प्रोसेस दैट आर इन द रेडी क्यूट एजुकेट एंड एलेट सीपीयू वन ऑफ अ एंड एलोकेट द
सीपीयू टू वन ऑफ़ देम रेडी से रनिंग में कौन जाएगा जो बार-बार बार-बार होगा यह डिसीजन लेगा शॉर्ट टर्म शेड्यूल शॉर्ट
टर्म क्यों बोल रहे हैं कोई प्रोसेस लॉन्ग टर्म शेड्यूलर के हाथ से जीवन में एक बार निकलेगी बट शॉर्ट टर्म में क्या है हो
सकता है प्रोसेसर मिले कोई हाई प्रायोरिटी प्रोसेस कांटेक्ट स्विच कर दे हो सकता है है प्रोसेसर मिले आप इनपुट आउटपुट की वजह
से बाहर आ जाएं तो अपने जीवन काल में कई बार आप रेडी से रनिंग पे जाएंगे लेकिन हर बार शॉर्ट टर्म शेड्यूलर के थ्रू जाएंगे
अब इन दोनों के बीच में आ जाता है मिडिल टर्म ये चीजों को बहुत अच्छे से मैनेज करता है इसकी कहानी सुनिए मिडिल टर्म
शेड्यूलर स्वैप प्रोसेस इन और आउट फ्रॉम द मेमोरी टू ऑप्टिमाइज सीपीय यूसेज एंड मेमोरी एलोकेशन
आईडिया समझिए कभी-कभी क्या होता है कि मेन मेमोरी के अंदर बहुत ज्यादा प्रोसेस आ जाती है और उसकी वजह से भीड़ बहुत ज्यादा
होती है बार-बार इनपुट आउटपुट ऑपरेशंस करने पड़ते हैं हर कोई सफिशिएंट अमाउंट ऑफ टाइम रन नहीं कर पा रहा होता और जो भी रन
करता है वो मेन मेमोरी में होता है हम जानते हैं तो मिडिल टर्म शेड्यूलर क्या करता है कुछ प्रोसेस को सस्पेंड कर देता
है आमतौर पर किनको विक्टिम बनाया जाता है जो वेटिंग स्टेट में है कुछ प्रोसेस को सस्पेंड करता है और कुछ समय के लिए दोबारा
से सेकेंडरी में भेज देता है कि यार अभी बहुत भीड़ बहुत ज्यादा है डिग्री ऑफ मल्टी प्रोग्रामिंग ज्यादा है फिलहाल कुछ समय के
लिए सो जाओ बाद में आपको रिज्यूम करेंगे और जब उसको लगता है कि अभी चीजें मैने जबल है तो उनको वापस लोड करता है तो यू नो डे
टू डे ऑपरेशंस मैनेज करना डिग्री ऑफ मल्टी प्रोग्रामिंग यानी कि फिलहाल मेन मेमोरी में कितनी प्रोसेस है ग ज्यादा तो नहीं हो
रही यू नो कुछ समय के लिए मैनेज करना इज द वर्क ऑफ द मिडिल टर्म शेड्यूलर सो बाय डूइंग दिस इट एडजस्ट द डिग्री ऑफ मल्टी
प्रोग्रामिंग फ्री अप द मेमोरी एज नीडेड सो पिंग अलाउ द सिस्टम टू पॉज एंड रिज्यूम अ प्रोसेस इंप्रूविंग द ओवरऑल सिस्टम
एफिशिएंसी तो ये परमानेंटली नहीं कर रहा कुछ समय के लिए पॉज कर देता फिर रिज्यूम कर लेगा यानी कि बाहर भेज देगा मेन से
सेकेंडरी में चले जा और फिर दोबारा सेकेंडरी से मेन में लेके आ जाएगा तो यह काम है मिडिल टर्म शेड्यूलर का अगेन मैंने
फिर से क्या किया है एक बड़ा सा टेबल बना के इन सब में बहुत अच्छे से डिफरेंशिएबल यू कैन गो देम यू कैन रिमेंबर
देम सो दैट एग्जाम में अगर कोई क्वेश्चन पूछता है शेड्यूलर्स पे व्हिच इज इन जनरल इंपॉर्टेंट टॉपिक तो आप उसको अच्छे से
आंसर करके आ सको गोइंग फर्द एक छोटी सी बात मुझे और करनी है द आइडियाज डिस्पैच डिस्पैच क्या होता है ये भी आपने शब्द कई
बार सुना होगा देखिए आमतौर पे शेड्यूलर जो होते हैं ना वो डिसीजन लेते हैं मान लीजिए शॉर्ट टर्म शेड्यूलर ने डिसीजन लिया कि
भाई अब अगला प्रोसेस p3 है जो जाएगा सीपीयू के अंदर बट वो सिर्फ डिसीजन लेता है उसका रियलिटी में इंप्लीमेंट टेशन कौन
कराता है तो डिस्पैच वो प्रोग्राम है जो रियलिटी में काम कराने वाले कैसे कराते हैं गौर करिए डिस्पैच इज अ मॉड्यूल दैट
गिव कंट्रोल ऑफ द सीपीयू टू द प्रोसेस सिलेक्टेड बाय द शॉर्ट टर्म शेड्यूलर उसको रियलिटी में कंट्रोल कौन दिलाता है
डिस्पैच दिलाता है कैसे दिलाता है गौर करिए सो स्विचिंग कांटेक्ट स्विचिंग फ्रॉम यूजर मोड जंपिंग टू प्रॉपर लोकेशन बेसिकली
ऐसे समझो आसान भाषा में जो प्रोसेस रन हो रही है उसका सारा डाटा फिलहाल उसके पीसीबी में सेव करना उसको बाहर निकालना नए
प्रोसेस को लोड करना जिसको शॉर्ट टर्म शेड्यूलर ने सेलेक्ट किया है उसके पीसीबी का डाटा सिस्टम के रजिस्टर्स में फिल करना
उस पॉइंट प लेके जाना और एग्जीक्यूशन चालू कराना यह सारा काम डिस्पैच का है जब यह काम हो रहा होता है उस समय क्या सीपीय
एग्जीक्यूशन कर सकता है नहीं अभी एक आदमी बाहर जाएगा और दूसरा अंदर आएगा उन बिटवीन तो कुछ काम होगा नहीं डिस्पैच ये पूरा काम
करने में जो समय लेता है उसको बोलते हैं डिस्पैच लेटेंसी या डिस्पैच ओवरहेड है ना किसी भी सिस्टम में डिस्पैच का टाइम जीरो
तो नहीं हो सकता बट ये प्योर वेस्टेज है क्योंकि यहां पे हम कुछ काम नहीं कर पा रहे होते तो अच्छा हार्डवेयर अच्छा
सॉफ्टवेयर हमारे पास होना चाहिए कोशिश करें विद इंटेंशन कि डिस्पैच लेटेंसी को कितना कम से कम किया जाए कम से कम किया जा
सके जीरो नहीं हो सकता बट नाउ व्हाट इज डिस्पेचर लेटेंसी एंड व्हाट इज डिस्पैच यू नो नाउ एक और छोटा सा पॉइंट सीपीयू बाउंड
इनपुट आउटपुट बाउंड आमतौर पे कोई भी प्रोसेस है कोई प्रोसेस ऐसी नहीं जो सिर्फ सीपीयू पे काम करे जो सिर्फ आईओ पे काम
करें मानते हो थोड़ा समय सीपीयू भी करना होता है थोड़ा समय इनपुट आउटपुट करना होता है बट प्रोसेस का एक टाइप होता है कि मान
लीजिए एक प्रोसेस है जो ज्यादातर समय सीपीयू में बिताए गी प्रोसेसिंग उसका ज्यादा करना है इनपुट आउटपुट प थोड़ा समय
जाएगा कुछ प्रोसेस उल्टे हो सकते हैं जो बोले हमें ज्यादातर इनपुट आउटपुट ऑपरेशन करना है कोई यूजर इंटरेक्शन है कोई चैट
बॉट है समथिंग लाइक दिस और सीपीयू थोड़ा सा काम करना है तो जो प्रोसेस अपने जीवन का ज्यादातर समय सीपीयू में काम करके
बिताती है थोड़ा बहुत इनपुट आउटपुट के साथ सा उनको बोलते हैं सीपीयू बाउंड प्रोसेस क्या बोलते हैं सीपीयू बाउंड और जो
प्रोसेस ज्यादातर समय इनपुट आउटपुट ऑपरेशंस करेंगे सीपीयू में थोड़ा कम काम करती है उनको बोलते हैं इनपुट आउटपुट
बाउंड प्रोसेस इनपुट आउटपुट बाउंड लॉन्ग टर्म शेड्यूलर का इन जनरल काम क्या होना चाहिए किसी भी समय सिस्टम के अंदर दोनों
का मिक्स होना चाहिए सोचो अगर सारे सीपीयू बाउंड होंगे तो इनपुट आउटपुट डिवाइसेज और हर कोई सीपीयू प वेट कर रहा होगा अगर सारे
आईओ बाउंड होंगे तो सीपीयू बेचारा खाली बैठा रहेगा एवरी बडी इज वेटिंग फॉर द इनपुट आउटपुट डिवाइस कि यार मेरे को
एलोकेट हो जाए अगर दोनों प्रोसेस होंगे तो काम बढ़िया चलेगा सिस्टम के रिसोर्सेस अच्छे से यूज होंगे कुछ प्रोसेस सीपीयू पे
काम करते रहेंगे और कुछ प्रोसेस इनपुट आउटपुट पे तो ये दोनों प्रोसेस के टाइप्स और इनका मिक्सचर इंपॉर्टेंट है व्हाट इज
कांटेक्ट स्विच अगेन आई हैव ऑलरेडी एक्सप्लेंड एक प्रोसेस जब डिसीजन हो जाएगा उस प्रोसेस के डाटा को मान लीजिए यहां पर
प्रोसेस पी नोट देखिए एग्जीक्यूट कर रहा था उसके डाटा को प प्रोसेस पीन के पीसीबी में सेव करना और उसके बाद प्रोसेस p1 जो
अभी तक आइडल था उसके डाटा को यू नो सिस्टम में लोड करना पीसीबी प्रोसेस वन के पीसीबी से सिस्टम में लोड करना यह जो पूरा काम है
इसको बोलते हैं कांटेक्ट स्विच करना तो एक प्रोसेस को बाहर निकालना और दूसरे प्रोसेस का डाटा लोड करना कांटेक्ट स्विच कहलाता
है तो आई थिंक जितने बेसिक बेसिक टर्म्स थे वो हमने सारे यहां पर डिस्कस कर लिए कुछ बहुत इंपॉर्टेंट डिस्कशंस भी किए जैसे
शेड्यूलर है या प्रोसेस का लाइफ साइकिल है उसके स्टेट्स हैं एंड देन अब हम वी आर वेरी मच रेडी टू गो फॉर सीपीयू शेड्यूलिंग
तो अभी बात करेंगे सीपीयू शेड्यूलिंग के बारे में जैसा सभी को पता नहीं पता है तो मैं बता देता हूं सीपीयू शेड्यूलिंग इज वन
ऑफ द मोस्ट मोस्ट मोस्ट इंपॉर्टेंट टॉपिक इससे तो क्वेश्चन आना ही आना है तो अभी आने वाला जो लगभग आधा घंटा बहुत ध्यान से
देखिएगा न्यूमेरिकल्स भी पूरा कवर करके चलेंगे प्रॉब्लम क्या है सो सीपीयू शेड्यूलिंग इज द प्रोसेस ऑफ डिटरमाइंस इन
द रेडी क्यू इज एलोकेटेड टू द सीपीयू भाई बहुत सारे प्रोसेस है रेडी क्यू के अंदर पूरा स्टेट डायग्राम पढ़ा तो अगला नंबर
किसका आने वाला है यह कौन डिसाइड करेगा उसके लिए एक एल्गोरिथम है व्हिच इज लाइक सीपीय शेड्यूलिंग एल्गोरिथम्स जो डिसाइड
करते है कि अगला प्रोसेस कौन सा जाएगा कौन-कौन सा एल्गोरिदम है तो अगर कुछ पॉपुलर की बात करूं एग्जाम पॉइंट ऑफ व्यू
से वेरी वेरी इंपोर्टेंट फर्स्ट कम फर्स्ट सर्व आपने नाम शायद सुना भी हो शॉर्टेज जॉब फर्स्ट या शॉर्टेज जॉब नेक्स्ट
प्रायोरिटी एंड राउंड ड्रबिंग ये चार मेन स्ट्रीम है एक दो आईडिया और है उसकी भी आगे डिटेल में बात
करूंगा कौन सा एल्गोरिथम अच्छा कौन सा खराब है कैसे डिसाइड ड करेंगे तो एक्चुअली अलग-अलग एल्गोरिथम ना अलग-अलग काइंड ऑफ
प्रोसेस को फेवर करते हैं हर किसी के कुछ एडवांटेज है कुछ डिसएडवांटेज है तो जब ये पूरी प्रोसेस हम समझ लेंगे तो एक यू नो एक
अंडरस्टैंडिंग हमारी डेवलप होगी किस तरह के सिनेरियो में शायद ये एल्गोरिथम अच्छा हो इस तरह की प्रोसेस के लिए शायद ये
एल्गोरिदम अच्छा हो लाइक डेटा स्ट्रक्चर्स मैं आपसे पूछूं बताओ एरे और लिंकलिस्ट में कौन सा अच्छा है तो आप नहीं बोल पाओगे ना
कहीं पे एरे शाद सूटेबल होगा कहीं पे लिंकलिस्ट सूटेबल होगा इसीलिए ऐसा पहले से मन में मान के नहीं चलना ये अच्छा और ये
खराब है हर किसी को सेम लेवल ऑफ अंडरस्टैंडिंग से समझेंगे नाउ अ शेड्यूलिंग के दो इंपॉर्टेंट
अप्रोचेबल था उसमें डिटेल में बात नहीं की थी अभी करता हूं एक अप्रोच दोस्तों होता है नॉन प्रिमिटिव शेड्यूलिंग एक होता है
प्रिमिटिव नॉन प्रिमिटिव मतलब जब कोई आपके साथ जबरदस्ती ना करें सारे पॉइंट्स मैंने मेंशन किए हुए हैं आईडिया देखिए यही
प्रोसेस का लाइफ साइकिल था तो रनिंग से अगर आप सीपीयू अपने मन से वॉलेटर छोड़ के बाहर जाते हैं तो इसको बोलते हैं नॉन
प्रीमप्टिव अप्रोच आप क्या करेंगे दो अप्रोच हो सकते हैं नंबर वन नंबर टू से मैंने मार्क किया है या तो आपका
एग्जीक्यूशन ही खत्म हो जाएगा एंड देन यू विल टर्मिनेटेड है ना बाहर चले गए अपने मन से एग्जीक्यूशन कंप्लीट हो गया प्रोसेस
एंड हो गया या तो ये हो सकता है या फिर जैसे मैंने बोला था कोई आपको इनपुट आउटपुट ऑपरेशन परफॉर्म करना है किसी दूसरे इवेंट
के लिए वेट करना फिलहाल आप खुद अपने मन से एग्जीक्यूशन नहीं करना चाहते तो आप कौन से स्टेट में चले जाते हैं वेटिंग स्टेट या
ब्लॉक्ड स्टेट लेकिन इन दोनों ही मन में याद रखिए दोनों ही केसेस में क्या किसी ने आपके साथ जबरदस्ती की क्या नहीं आप वॉलेटर
अपने मन से बाहर आए अगर इस तरह की शेड्यूलिंग हो कि हम किसी प्रोसेस को कभी बाहर नहीं निकालते वो खुद ही बाहर आएगी
सीपी से इसको बोलते हैं नॉन प्रीमप्टिव अप्रोच दूसरा अप्रोच हो सकता है क्या प्रीमप्टिव अप्रोच एंड व्हाट इज दिस ये
वाले दोनों आईडिया तो है ही है जो बाहर आ रहे हैं रनिंग से मैं आपको रेडी में लेके जा रहा हूं दो अप्रोच समझाता हूं मान
लीजिए अप्रोच नंबर थ्री है हमारा क्या प्रायोरिटी वाला हम एग्जीक्यूशन कर रहे थे बट ड्यूरिंग द एग्जीक्यूशन एक नया प्रोसेस
सिस्टम में करता है जिसकी प्रायोरिटी हमारे प्रायोरिटी से ज्यादा है यस तो क्या करना पड़ेगा रनिंग प्रोसेस को बीच में
रोकना पड़ेगा कि भाई आप बाद में काम करना आप रेडी में आ जाओ किसी नए प्रोसेस को लोड करेंगे जिसका प्रायोरिटी ज्यादा है या
राउंड रॉबिन आगे समझेंगे जहां पर हर प्रोसेस को एक टाइम क्वांटम दिया जाता है फिक्स टाइम क्वांटम एक बार में मैक्सिमम
इतना ही एलोकेट कर सकते हो फॉर एग्जांपल दो यूनिट्स ऑफ टाइम और ज्यादा करना है मना नहीं कर रहे अभी बाहर आ जाओ कुछ लोगों को
और काम करने दो थोड़ी देर के बाद फिर से तुम्हें अंदर प्रोसेसर एलोकेट करेंगे है ना तो ये दोनों ही अप्रोच जो हैं जहां पे
हम फोर्सफुली बाहर निकालते हैं या तो राउंड रॉबिन की वजह से टाइम क्वांटम की वजह से या फिर प्रायोरिटी की वजह से ये
कहलाता है नॉन प्रिमिटिव सॉरी ये कहलाता प्रिमिटिव अप्रोच है ना जिसमें जबरदस्ती नॉन जबरदस्ती ये दो अंडरस्टैंडिंग है
मैंने फिर भी प्रिमिटिव नॉन प्रिमिटिव जैसा मैं कर रहा हूं इस वीडियो के अंदर पूरा डिफरेंस किया है यू कैन गो थ्रू दीज
पॉइंट्स चाहो तो याद करो एग्जाम में कोई पूछे तो और अच्छे से डिटेल्स आंसर करने के लिए मैं आगे बढ़ता हूं तो अगेन अ ये जैसे
मैंने आपसे बताया कि हर एल्गोरिदम का अप्रोच अलग है और कुछ क्राइटेरियास हो सकते हैं जिस बेस पे हम जज करें जैसे मान
लीजिए एल्गोरिथम है एक जो सबसे इंपॉर्टेंट क्राइटेरिया होगा वो होगा टाइम एग्जीक्यूशन टाइम जो कम से कम टाइम लेगा
वो उतना अच्छा एल्गोरिथम उसी तरह यहां पर सीपीयू शेड्यूलिंग में भी कुछ इंपॉर्टेंट क्राइटेरियास हैं जिसको हम जज करते हैं
जिसके बेस पे देखते हैं कि वो एल्गोरिथम अच्छा काम किया कि बेकार काम किया उन क्राइटेरियास को समझना बहुत जरूरी है एक
बड़ा इंपॉर्टेंट कॉमन सेंस क्राइटेरिया है लाइक सीपीय यूटिलाइजेशन इसका मतलब क्या है यह देखता है कि जो भी एल्गोरिथम आप यूज कर
रहे हो हमारा सीपीयू कितने परसेंटेज ऑफ द टाइम बिजी है और ओबवियस अप्रोच है कि वो एल्गोरिथम जो सीपीयू को ज्यादा से ज्यादा
समय के लिए बिजी रखेगा हम मानेंगे कि वो अच्छा एल्गोरिथम है वो बेटर काम कर रहा है जो बिजी नहीं रखेगा वो खराब काम कर रहा है
बट ये एक अप्रोच आप देख सकते हैं जो लोग लाइन में खड़े हुए उन्हें लग रहा है कि मैडम शायद बहुत बिजी है इसीलिए बैंक अभी
काम नहीं कर पा रहा बट यहां पे कार्ड्स खेले जा रहे हैं कुछ अलग कारण भी हो सकते हैं मे बी बोलते हैं ना इंटरनेट डाउन और
समथिंग लाइक दिस बट कभी-कभी क्या है ना पॉइंट ये है कि सीपीयू आप बिजी करके रखा है बट कुछ रियलिटी में काम नहीं हो रहा
कोई थ्रू पुट नहीं आ रहा तो दूसरा एक इंपॉर्टेंट पॉइंट हो सकता है अगेन थ्रू पुट व्हाट इज थ्रू पुट यू नो नंबर ऑफ
प्रोसेस एग्जीक्यूटेड पर यूनिट टाइम केस टू केस डिफर कर सकता है अब इमेजिन य शायद कोई कार मैन्युफैक्चरिंग कंपनी है तो इनका
थ्रू पट क्या होगा ये मत बताओ किसने कितना काम किया सर बहुत बिजी थे सर यह किया यह बताओ पू पूरे दिन में फैक्ट्री में से
कितनी गाड़ियां बाहर आई ठीक उसी तरह यहां पे हम बोल सकते हैं कि आपने सीबीयू को बिजी रखा दैट इज अनदर थिंग वर्क क्या डन
हुआ कितने नंबर ऑफ प्रोसेस पर यूनिट टाइम एग्जीक्यूट कर रहे हैं और जो एल्गोरिथम ज्यादा अच्छा थ्रू पुट देगा हम मानेंगे वो
बेटर सीपीयू शेड्यूलिंग एल्गोरिदम है तो दिस कुड आल्सो बी एन आईडिया एक हो सकता है वेटिंग टाइम हम एवरेज वेटिंग टाइम
कैलकुलेट करेंगे और इन जनरल अगर एल्गोरिदम अच्छा है तो प्रोसेस को ज्यादा वेट करना पड़ेगा कि कम वेट करना पड़ेगा प्रोसेस को
कम वेट करना पड़ेगा तो ये तो कोई बहुत लंबी प्रोसेस लग रहा है नजर आ रही है तो वो एल्गोरिथम जिसका एवरेज वेटिंग टाइम कम
होगा वो बेटर कहलाएगा आगे बढ़ी एक अप्रोच हमारे पास क्या हो सकता है रिस्पांस टाइम ये वेटिंग टाइम से थोड़ा सा लग आईडिया है
जैसे मैं इस एग्जांपल से समझाना चाहता हूं आमतौर पे आपने कई बार गोलगप्पे खाए होंगे तो एक बार जब आपको गोलगप्पा मिला पहली बार
तो ऐसा नहीं कि एक साथ सारे मिल जाते हैं अ शायद आप चाहते भी नहीं हो तो आप उसे एंजॉय करोगे देन यू नो इन अ राउंड रॉबन
फैशन साइकिल घूमेगी फिर आपके पास आएगी तो हो सकता है मे बी फर्स्ट गोल गप्पे के लिए आपको मान लीजिए चार खाने हैं मैं सिंपल
केस मान के चल रहा हूं तो पहले के लिए हो सकता है आपको 30 सेकंड वेट करना पड़े और फिर हर किसी के लिए 30 30 30 वेट करना
पड़े अब यहां पर टोटल वेट कितना हुआ तो टोटल वेटिंग टाइम तो हो गया आपका 2 मिनट्स इजन इट 60 सेकंड 60 सेकंड 120 ू मिनट्स हो
गया 120 सेकंड्स और टू मिनट्स लेकिन अगर हम रिस्पांस टाइम देखेंगे दैट इज 30 सेकंड तो व्हाट इज रिस्पांस टाइम पहली बार जब
आपको रिस्पांस मिल जाए उसको बोलते हैं रिस्पांस टाइम राउंड रॉबिन आमतौर पे रिस्पांस टाइम में बहुत अच्छा परफॉर्म
करता है तो रिस्पांस टाइम भी एक इंपॉर्टेंट क्राइटेरिया है इट इज द टाइम टेकन टू स्टार्ट रेस्पॉन्डिंग टू द टाइम
इट टेक द आउ टू आउटपुट द रिस्पांस पहली बार जब मैं आपको रिस्पांस करने में जितना समय लूंगा जब आप रिस्पांस मांगेंगे उसको
बोलेंगे रिस्पांस टाइम तो ये कुछ अलग-अलग क्राइटेरियास है और जैसे मैं आपसे बोल रहा हूं कि अलग-अलग क्राइटेरियास अलग-अलग
एल्गोरिथम बिहेव करेंगे वो क्या रिस्पांस होगा हम देखेंगे एक बात और यहां पर समझ लेते हैं
इस पॉइंट पर बाद में आता हूं पहले जरा कुछ इंपॉर्टेंट टर्मिनोलॉजी आपसे डिस्कस कर लूं वैसे तो न्यूमेरिकल्स में विविल गो ईच
ऑफ देम वन बाय वन पहला टर्म होता है अराइवल टाइम कई बार आपने सुना होगा नहीं सुना अभी समझिए अराइवल टाइम जब कोई
प्रोसेस सिस्टम में आता है टू बी प्रोसाइज रेडी क्यू में आता है और बोलता है मैं एग्जीक्यूशन के लिए रेडी हूं उसको बोलते
हैं अराइवल टाइम द टाइम एट विच अ प्रोसेस एंटर्स अ रिडी क्यू उससे पहले प्रोसेस मेरे किसी काम का नहीं है मैं उसको
शेड्यूल तो कर नहीं सकता सीपीयू प शेड्यूल कब कर सकता हूं जब वो रेडी क्यू में होगा तो दैट इज मेंशन बाय अराइवल टाइम बस टाइम
उसको सीपीयू पे कितना टाइम चाहिए देखिए टॉपिक का नाम ही सीपीयू शेड्यूलिंग है इनपुट आउटपुट डिवाइसेज यहां पे हमारे लिए
कोई खास इंपॉर्टेंस फिलहाल नहीं रखते तो सीपीयू एग्जीक्यूशन के लिए कितना टाइम चाहिए उसको बोलेंगे बस टाइम ये मैं डिसाइड
नहीं करूंगा तो प्रोसेस पहले से डिसाइड करके आएगा और मैं इसको चेंज कर भी नहीं सकता मैं यह तो कर सकता हूं अब फॉर
एग्जांपल मैं एक रेस्टोरेंट चला रहा हूं अगर किसी आदमी को चार रोटी खानी है भाई चार ही खाएगा ना मेरे हाथ में बस यह है
मैं इसको पहले खिलाऊ इसको बाद में खिलाऊ पहले दो इसको खिलाऊ दो किसी और को खिलाऊ यह मैनेज मैं कर सकता हूं तो बस टाइम इसको
कितना टाइम चाहिए कंप्लीशन टाइम कोई प्रोसेस किस समय सिस्टम से बाहर जाता है तो मान लीजिए अगर अराइवल हुआ 12 ब 10 पे
और लेट मी से बाहर गया वो 12:30 पे सो दिस इज अराइवल टाइम दिस इज कंप्लीशन टाइम टर्न अराउंड टाइम कंप्लीशन टाइम माइनस अराइवल
टाइम कोई प्रोसेस कितने समय के लिए सिस्टम में था तो यह भाई साहब 12:00 ब 30 मिनट पे बाहर गए और आए थे 1210 पे तो मान लीजिए
ओवरऑल 20 मिनट्स के लिए सिस्टम में था दैट इज नोन एज टर्न अराउंड टाइम टोटल कितने समय के लिए आप सिस्टम में थे नेक्स्ट इज
वेटिंग टाइम इस पूरे समय में आपने कितने समय वेट किया तो जब कोई प्रोसेस यहां पर है और हम मान रहे हैं इनपुट आउटपुट कंसीडर
नहीं करना आप सिस्टम में सर आप दो ही काम करोगे या तो आप एग्जीक्यूट करोगे यानी कि या तो आप रेडी क्यू में रनिंग स्टेट में
होंगे या तो आप एग्जीक्यूशन के लिए वेट कर रहे हैं यानी कि आप रेडी क्यू में है तो टर्न अराउंड ये जो वेटिंग टाइम है इसको आप
ऐसे समझ सकते हैं इट इज द टर्न अराउंड टाइम माइनस बस टाइम वेटिंग टाइम अगर निकालना है तो आप टोटल कितने समय सिस्टम
में थे जैसे मान लीजिए प्रोसेस कहता है कि मेरा बस टाइम तो सिर्फ 5 मिनट का था तो हम देख रहे हैं ये 20 मिनट के लिए सिस्टम में
था 1210 से 12:30 तक ये सिस्टम में था रन इसने किया सिर्फ 5 मिनट तो बाकी समय क्या किया वेट किया तो टर्न अराउंड टाइम था 20
मिनट्स अब ये खुद से बोल रहा है कि रन इसने सिर्फ 5 मिनट किया तो इसका मतलब 15 मिनट के लिए सिस्टम में वेटिंग टाइम था
इसका वेटिंग मतलब यह रेडी क्यू में था प्रोसेसर के लिए वेट कर रहा था बाकी तो न्यूमेरिकल्स में और आपको मजा आएगा बट यह
बेसिक टर्मिनोलॉजी मेरे हिसाब से क्लियर होना चाहिए था यस नाउ वी एंटर इन टू द फर्स्ट एल्गोरिथम व्हिच इज
एफसीएफएस नाम से भी इसका काम समझ आता है फर्स्ट कम फर्स्ट सर पहले आओ पहले पाओ तो सबसे सिंपल सबसे कॉमन अप्रोच हो सकता है
जिसमें कोई दिमाग लगाने की जरूरत नहीं है आईडिया क्या है जब भी कोई प्रोसेस सिस्टम में एंटर करेगा तो सब से पहले सीपीयू
किसको एग्जीक्यूट होने वाला है सबसे पहले उसको एग्जीक्यूट होगा जो पहले आया था बात खत्म यहां कोई प्रायोरिटी नहीं चलेगी दिस
इज ऑफ नॉन प्रीमप्टिव नेचर एक बार अगर सीपीयू मिला तो मिला जब तक एग्जीक्यूशन कंप्लीट नहीं होगा तब तक उसको बाहर नहीं
निकालेंगे ओबवियसली क्यू इज अ वेरी सिंपल अप्रोच जिसके थ्रू आप इसे इंप्लीमेंट कर सकते हैं एक छोटा सा केस आपको करके दिखाता
हूं तो देखिए पूरा टेबल यहां पर हमारे पास है कितने प्रोसेस हैं p न से p4 तक फाइव प्रोसेस है जरा गौर करिए अराइवल टाइम पर
मुझे बताइए सबसे ऐसा मत करिएगा p न कोही रन करना चालू कर दिया ना बताओ सबसे पहले कौन आया सर सबसे पहले p2 आया तो टाइम जीरो
पर प2 ने लगाई एंट्री कितना समय चाहिए थ्री यूनिट्स तो मैं बोल रहा हूं इसको फर्क नहीं पड़ता एक बार एलोकेट किया तो
किया इट इज ऑफ नॉन प्रीमप्टिव नेचर तो अब तीन यूनिट तक p2 चला अब जब p2 बाहर आया सीपीयू खाली है फिर देखेंगे अभी अगला
सीनियर कौन है अगला सीनियर है p1 जो कि वन पे आया था दो यूनिट इसको चाहिए तो थ्री से फाइव तक गौर करिए कौन चलेगा p1 चलेगा फिर
आगे बढ़ी अगला नंबर अगला नंबर यह p0 आया था चार यूनिट का रिक्वायरमेंट है तो p0 कहां से कहां चलेगा 5 + 4 हो जाएगा 9 यह
चले p0 भाई साहब फिर बताइए अच्छा p4 पहला आ है थ्री पर आई वलब सिंगल यूनिट का रिक्वायरमेंट है 9 + 1 हो गया 10 p4 और
सबसे लास्ट में आया था सबसे लास्ट में इसे प्रोसेसर मिलेगा क्या नाम है इसका p3 तो p3 को यहां पर प्रोसेसर मिल जाता है कितने
यूनिट के लिए दो यूनिट के लिए चाहिए था दो के लिए मिलता है तो यह कहानी हो गई यस अब इसको बोलते हैं गैन चार्ट ये एग्जाम में
बनाना बहुत जरूरी है न्यूमेरिकल जब आप सॉल्व करेंगे जैसे ही चार्ट बना कंप्लीशन टाइम समझ आ गया पन बाहर गए नान पर
p1 बाहर गया है 5 पर p2 बाहर गया थ पर p3 बाहर गया 12 पर यू नो सबसे लास्ट में एंड p4 बाहर गया 10 पर अब जो हमने पहले
अंडरस्टैंडिंग ले रखी है जैसे ही आपको पता लगा कंप्लीशन टाइम कि कौन कितने समय बाहर गया अराइवल टाइम आपको पहले से पता है कौन
कब आया था तो इससे आप क्या निकाल सकते हैं टर्न अराउंड टाइम माइनस करिए ये टू पे आया था वन पे आया था जीरो पे आया था फोर पे
आया था थ्री पे आया था तो इसका टर्न अराउन टाइम हुआ सेवन इसका हुआ फोर इसका हुआ थ्री इसका हुआ एट इसका हुआ सेवन अगेन जब टोटल
सिस्टम में कितना टाइम बिताया यह पता आपको लग गया तब आप क्या कर सकते हैं माइनस करिए इनका एग्जीक्यूशन टाइम पता लगेगा किसने
कितना वेट किया तो एग्जीक्यूशन टाइम कितना था इसका फोर था इसका टू था इसका थ्री था इसका टू था इसका वन था सो दैट विल बी थ्री
दैट विल बी टू दैट विल बी जीरो दैट विल बी सिक्स दैट इज आल्सो सिक्स इसमें कोई छोटा-मोटा कैलकुलेशन मिस्टेक हुआ हो रन
टाइम पर रिकॉर्ड कर रहा तो माफ करिएगा पहले से ऐसे सॉल्व करके नहीं रखा ताकि थोड़ा फील आए आपको एग्जांपल चेक करते हैं
यह प्रोसेस सिक्स यूनिट वेट कर रहा है कौन है ये p4 चेक करना आया था चार पे और प्रोसे p3 माफ कीजिएगा आया था चार पे देखो
प्रोसेसर मिला 10 पे चार और 10 का डिफरेंस हां छ यूनिटी वेट किया कभी-कभी आपसे बोल सकते हैं एवरेज बताओ एवरेज बता दो तो
एवरेज टर्नर ऑन टाइम क्या करेंगे 7 + 4 लाइक दिस अप टिल अप टिल सेवन टोटल कितने प्रोसेस है 1 2 3 4 5 डिवाइड कर दो
सिमिलरली एवरेज वेटिंग टाइम सबका टाइम प्लस करो डिवाइड बाय फाइव कर दो क्योंकि फाइव प्रोसेस है तो दैट इज हाउ यू कैन
सॉल्व अ न्यूमेरिकल जो पूछा जाता है एडवांटेज की बात करें बहुत सिंपल है इजी टू इंप्लीमेंट है आसान है समझना समझाना सब
और जो खासकर वो प्रोसेस है ना जो बड़े अर्जेंट नेचर के नहीं है क्योंकि ये तो तसल्ली से भाई साहब जो पहले आएगा उसके काम
करेंगे मुझे प्रायोरिटी समझ नहीं आ रही मुझे राउंड ड्रॉबिन मुझे रिस्पांस नहीं समझ आ रहा मैं तो बेसिक तरह से काम करता
हूं तो वहां पर ये सूटेबल काम करता है यस क्या एफसीएफएस के अंदर कुछ प्रॉब्लम है जो हमें एक हिंट देगा हमें आईडिया देगा अगले
एल्गोरिथम की तरफ जाने का जो है शॉर्टेज जॉब फर्स्ट तो एक छोटा सा प्रॉब्लम आपसे डिस्कस करता हूं फिर एक बार पूरा पैटर्न
ऑब्जर्व करेंगे यहां देखिए दो टेबल मेरे पास है p न और p1 दो प्रोसेस है और अगर जल्दी से मैं आपसे रिक्वेस्ट करूं कि यार
चलो इनका अपन चार्ट बनाते हैं तो एक बार ऑब्जर्व करते हैं देखिए क्या होगा तो एट टाइम जीरो मेरे पास एक ही प्रोसेस है बट
बहुत बड़ा प्रोसेस है 100 यूनिट्स का रिक्वायरमेंट है तो p नॉ अन डाउटेड शेड्यूल होगा 100 तक प्रोसेस p1 व पे आ
गया था बट प्रोसेसर मिलेगा 100 पे क्योंकि कांटेक्ट स्विच हो नहीं सकता रिक्वायरमेंट है मात्र दो यूनिट का तो 100 से 102 तक ये
कौन चलेगा p1 चलेगा बट अगेन मैं देखूं एवरेज वेटिंग अगर मेरे को देखना हो p न ने तो कोई वेट नहीं किया जीरो पे आया जीरो पे
प्रोसेसर मिला बट p11 पे आया था 100 प प्रोसेसर मिला 99 वेट कि अगर मैं एवरेज भी करता हूं तो मेरा एवरेज वेटिंग टाइम आता
है 49.5 जो कि बहुत ज्यादा है अब अगर आप इधर देखिए यहां पर बस एक ही चेंज किया है कि जो बड़ा प्रोसेस है उसको बाद में रख
दिया छोटे को पहले रख दिया तो 0 पर p1 आया और आते ही उसको प्रोसेसर मिला 0 सेट तक p1 चलेगा और वन पे आया था पन अब वो 100
यूनिट्स के लिए पन को शेड्यूल कर देता है चलेगा 102 तक तो हालांकि देखिए पन पे कुछ खास फर्क नहीं पड़ा क्योंकि p1 का वेटिंग
टाइम मैं मानता हूं जीरो ही रहेगा लेकिन p1 वन पे आया था टू पे प्रोसेसर मिला उसको सिर्फ वन यूनिट वेट करना पड़ा एवरेज
देखेंगे फ तो यहां पर एक बड़ा इंपॉर्टेंट मोटिवेशन हमें मिलता है वो क्या एफसीएफएस में क्या हो रहा है कभी-कभी ना बड़े
प्रोसेस के चक्कर में छोटे प्रोसेस फस जाएंगे अगर कोई बड़ा प्रोसेस पहले आ गया तो छोटे प्रोसेस का वेटिंग टाइम बहुत
ज्यादा बढ़ जाता है लेकिन अगर हम छोटे प्रोसेस को पहले रन करें तो बड़े प्रोसेस के वेटिंग टाइम पे इतना कुछ खास फर्क नहीं
पड़ रहा है इस प्रॉब्लम को हम बोलते हैं कन्वोय इफेक्ट देखिए एक बड़ी इंपोर्टेंट बात है यहां पर हम स्टार्वेशन शब्द यूज
नहीं करते हम ये नहीं कहते कि जो प्रोसेस बाद में फंस गया वो स्टार्वेशन में है क्योंकि पहले आओ पहले पाव वाली बात थी तो
प्रोसेसर तो बायस नहीं है अगर आपको पहले नंबर आना था आपको पहले आना चाहिए था लेकिन ये एक प्रॉब्लम जरूर है जिसको बोलते हैं
कन्वोय कन्वोय मतलब काफिला तो यहां पे आप देख रहे हैं बहुत सारे कोई कोई मिनिस्टर है जिसका कन्वोय जा रहा है तो बहुत सारे
लोग साइड हालांकि ये तो मेरे को लग रहा है मजे लेने आया है बट अगर आपको रो क्रॉस करनी हो जैसे यहां देखिए एक ट्रेन है बड़ी
प्रोसेस है इन भाई साहब को रोड क्रॉस करने में हो सकता है 10 सेकंड लगे ट्रेन को हो सकता है क्रॉस करने में दो मिनट लगे लेकिन
अब क्योंकि फस्ट कम फस पहले ट्रेन आ गई है अब सबको वेट करना पड़ेगा तो व्हाट इज अ कन्वो इफेक्ट जब बड़ी प्रोसेस की वजह से
छोटे प्रोसेस को बहुत ज्यादा समय के लिए वेट करना हो इस प्रॉब्लम को हम बोलते हैं कन्वोय इफेक्ट और यह प्रॉब्लम जो कि
एफसीएफएस में है हमें मोटिवेशन देती है हमें हंट देती है इसका मतलब क्या करना चाहिए करना यह चाहिए कि छोटे प्रोसेस को
पहले पले एग्जीक्यूट करो और छोटे प्रोसेस को पहले एग्जीक्यूट करने का आईडिया ही है शॉर्टेस्ट जॉब फास्ट यस और कोई
डिसएडवांटेज अ अगेन दिस इज द बेसिक आइडिया आई थिंक एफसीएफएस हमने कंप्लीट कर लिया नाउ टॉकिंग इन द आइडिया ऑफ शॉर्टेज ऑफ
फर्स ये कैसे काम करेगा मैं एक एक करके पैटर्न बाय पैटर्न चलता हूं फिर जो डाउट जो कंफ्यूजन होगा आप मुझे बताइएगा इसके
अगेन दोनों वेरिएंट्स हमारे पास है हमारे पास प्रिमिटिव वेरिएंट भी है और नॉन प्रिमिटिव वेरिएंट भी है तो कैसे इस पे
काम कर सकते हो और क्या आईडिया होगा क्या एजेंडा होगा यह समझ आएगा एक पूरा क्वेश्चन सॉल्व करके तो यहां पर एक न्यूमेरिकल
हमारे पास है शॉर्टेस्ट जॉब फर्स्ट के दोनों वेरिएंट हमारे पास है प्रिमिटिव और नॉन प्रिमिटिव क्वेश्चन सॉल्व करने के साथ
आपको समझाता हूं तो बढ़िया सा एक न्यूमेरिकल है शुरू करते हैं वन बाय वन तो यहां पर देखिए बहुत सारी प्रोसेस मेरे पास
है पहले जो वेरिएंट हम सॉल्व करेंगे वो सॉल्व करेंगे नॉन प्रिमिटिव वर्जन एट टाइम जीरो कितनी प्रोसेस मेरे पास है टाइम जरो
प कोई भी प्रोसेस मेरे पास नहीं है आप देख रहे हो पहले प्रोसेस का अराइवली जीरो पे है वन पे है जानबूझ के ऐसा केस रखा है
ताकि इस तरह का कोई केस हो तो कंफ्यूजन ना हो अभी नहीं है तो नहीं करू क्या ही करूं एट टाइम वन मेरे पास एक प्रोसेस है अब
देखिए जब एक ही प्रोसेस है तो डू आई एक्चुअली नीड अ सीपीय शेड्यूलिंग एल्गोरिथम नो भाई जो है वही रन होगा उसकी
कोई प्रायोरिटी वो पहले आ बाद में क्या करूं तो जो पहली प्रोसेस है रन करना शुरू करता हूं और प्रोसेस का नाम है p न अब
यहां पर देखिए एक बात सोचनी पड़ेगी प्रिमिटिव वर्जन के नॉन प्रिमिटिव वर्जन पहले कर रहा हूं सिंपल नॉन प्रिमिटिव
वर्जन नॉन प्रिमिटिव वर्जन क्या कहता है एक बार शेड्यूल हो गया तो प्रोसेस को फोर्सफुली सीपीयू से बाहर नहीं निकाल सकते
वो वॉलेटर अपने मन से ही बाहर आएगा तो वही मैं भी करूंगा प्रोसेस बहुत बड़ा है सेन यूनिट का बस टाइम रिक्वायरमेंट है तो 1 +
7 यानी कि यह भाई साहब चलने वाले हैं 8 तक और पूरा करके ही ये बाहर आएगा कोई इससे फोर्सफुली प्रिम नहीं कर सकता नाउ एट टाइम
एट व्हेन आई सी सारे प्रोसेस मेरे पास आ चुके हैं अभी तो बल्ले-बल्ले हैं अब आप देखो सबसे छोटा प्रोसेस छोटा प्रोसेस पहले
तो सबसे पहले रन करूंगा p2 मात्र एक यूनिट का रिक्वायरमेंट है तो 8+ 1 9 तक ये चलने वाला है छोटे के हिसाब से देखूंगा अगला
नंबर आएगा p 3 का सो नेक्स्ट प्रोसेस इज p3 दो यूनिट का रिक्वायरमेंट है सो 9 + 2 11 तक यह चलेगा अगला नंबर है p1 का फाइव
यूनिट्स का रिक्वायरमेंट है तो 11 + 5 यानी कि 16 तक कौन चलेगा p1 चलने वाला है एंड सबसे लास्ट में सबसे बड़ा प्रोसेस 8
यूनिट का रिक्वायरमेंट है तो 8 16 + 8 आई थिंक 2424 क्या नाम है भाई साहब इसका इसका नाम है p4 तो यह पूरी कहानी हमारी कंप्लीट
हो गई बाकी कलेशन तो आप कर सकते हो पहले की तरह अब पूरा गेम है नॉन प्रिमिटिव तो नॉन सॉरी नॉन प्रिमिटिव हो चुका है पूरा
गेम है प्रिमिटिव प्रिमिटिव करके दिखाता हूं यहां पे आपको आएगा मजा तो नॉन प्रिमिटिव आप समझ गए एक बार अगर शेड्यूल
कर दिया फिर बीच में कोई भी प्रोसेस आए मेरे को इस बात से कोई लेना देना नहीं है मैं उसी हिसाब से चलूंगा है ना यहां पर
गेम में क्या गेम है दिखाता हूं एट टाइम जीरो मैंने स्टार्ट किया टाइम जीरो पर कोई प्रोसेस नहीं है तो रो से वन तक पहले की
तरह कोई नहीं चलेगा वन प आ p न बट इस बार मैं p न को लास्ट तक शेड्यूल नहीं करूंगा मैं तब तक शेड्यूल करूंगा जब तक अगली
प्रोसेस नहीं आती और वहां पे रुक के लूंगा मैं डिसीजन तो वन से मैंने शुरू किया और प्रोसेस का नाम है क्या प्रोसेस का नाम है
p नॉ ये कब तक चलेगा जब तक अगली प्रोसेस नहीं आ रही वो आ रही है टू पे तो वन से टू तक सिर्फ एक यूनिट मैंने चलाया तो कितना
बचा सिक्स एंड नाउ आई विल टेक अ डिसीजन जो नया प्रोसेस आया है उसका टाइम है फाइव जो करंट प्रोसेस है उसका रिमेनिंग टाइम भी
सिक्स है नाउ पीइंग प्योर ग्रीडी शॉर्टेज ऑफ फस को क्या करना चाहिए जो छोटा प्रोसेस है उसको रन करना चाहिए तो मैं रन करने
वाला हूं सर अ p1 को मैं इसको धोखा दूंगा छोड़ दूंगा p1 को रन करूंगा लेकिन कब तक जब तक अगला प्रोसेस नहीं आता वो आ रहा है
थ्री पे तो टू से थ्री तक अब मैं रन करने वाला हूं किसको सिंगल यूनिट p1 को रन करूंगा लेट मी राइट p1 और ये बचेगा फोर बट
यू नो बुरे के साथ बुरा होता है डबल क्रॉस हो जाएगा p1 ने p न को डबल क्रॉस किया टाइम थ्री पर एक नई प्रोसेस p p2 ने
एंट्री लगाई है जिसका रिमेनिंग टाइम है वन अभी शॉर्टेज जो फर्स्ट के हिसाब से तो सोना इसी को पहले रन करना पड़ेगा तो नाउ
आई एम गोइंग टू रन दिस p2 फॉर वन यूनिट एंड थ्री से फोर तक छोटा होने की वजह से सबसे पहले रन हो के बाहर गया अब चार था
शायद दोबारा नंबर आने वाला था बट देखिए फोर पे दोबारा से एंट्री लगाई एक नई प्रोसेस p3 ने जिसका बस टाइम रिक्वायरमेंट
है टू जो कि सिक्स और फोर दोनों से कम है तो p3 को भी आते ही रिस्पेक्ट करना चाहिए सिक्स तक मैं रन कर देता हूं किसको p3 को
देखिए ये भी यहां से से हो गया बाहर एट टाइम सिक्स नाउ आई थिंक सभी आ चुके हैं अब आप शॉर्टेस्ट जॉब फर्स्ट के हिसाब से चलना
शुरू करिए तो अगला नंबर यह पेंडिंग है फर यूनिट इसको दीजिए p1 को फर यूनिट का रिक्वायरमेंट है तो यह 6 + 4 हो जाएगा 10
ये गया बाहर नाउ एट टाइम 10 अगला नंबर दीजिए किसको p न को अ सिक्स यूनिट्स का रिक्वायरमेंट है तो 10 + 6 हो गया 16 16
ये गया बाहर और सबसे लास्ट में आपको मिलेगा p4 एट यूनिट्स का रिक्वायरमेंट है तो यह मैं इसका बचारे का न बाद में ही आया
सो दैट इज हाउ आई थिंक प्रिमिटिव और नॉन प्रिमिटिव में क्या डिफरेंस है तो प्रिमिटिव अप्रोच आपने देख लिया जब भी कोई
नया प्रोसेस आता है हम करंट प्रोसेस को रुक के देखते हैं कि जो नया प्रोसेस आया क्या उसका टाइम करंट प्रोसेस के रिमेनिंग
टाइम से भी कम तो नहीं है और अगर कम है तो हम कांटेक्ट स्विच करते हैं अगर बराबर होगा तो जो चल रहा है उसको चलने देंगे उस
केस में बिकॉज फिर अगेन इट विल बी अ वेस्ट ऑफ टाइम क्योंकि कांटेक्ट स्विच में भी तो कुछ टाइम वेस्ट होता है बहुत माइन्यूट
होता है बट होता है तो यह बेसिक बात आपको समझ आ गई एडवांटेज की अगर बात करें तो अगेन जो प्रिमिटिव वर्जन है एज फार एज
वेटिंग टाइम इज कंसर्न वी कैन से कि यार इससे अच्छा कोई काम कर ही नहीं सकता इसीलिए प्रिमिटिव वर्जन को हम क्लियर कट
ऑप्टिमल भी बोलते हैं ऑप्टिमल क्यों क्योंकि गारंटी करता है मिनिमम टाइम देगा यस तो ये बड़ा एडवांटेज है डिसएडवांटेजेस
की बात करूं तो दो डिसएडवांटेज यहां पे आपको देखने के लिए मिलेंगे पहला डिसएडवांटेज क्या है कि यह जो पूरा का
पूरा आईडिया है इसमें वो प्रोसेस जिनका टाइम रिक्वायरमेंट ज्यादा है वो स्टार्वेशन में जाएंगे है ना उनकी क्या
गलती होती है हर बार छोटा प्रोसेस आएगा रन होता जाएगा छोटा प्रोसेस आएगा रन होता जाएगा तो दैट विल बी अ काइंड ऑफ अ
प्रॉब्लम सेकंड प्रॉब्लम जो कि इतनी प्रैक्टिकल है जिसके बाद हर चीज बकवास लगेगी आपको ये एल्गोरिदम इंप्लीमेंटेबल ही
नहीं है जी हां क्यों क्योंकि पूरे एल्गोरिदम का आप सोचो ना यार एक बार पूरे एल्गोरिथम का डिपेंडेंस है बस टाइम पे पर
हमें क्या रियल लाइफ में किसी प्रोसेस जब कोई नया प्रोसेस आता है किसी भी सिस्टम में हमें उसका बस टाइम पता होता है क्या
हमें पता हो क्या प्रोसेस पता होता है क्या कि प्रोसेस कितने टाइम रन करेगा हमें तो नहीं पता होता तो जब बस टाइम ही नहीं
पता तो यही शेड्यूलिंग क्राइटेरिया पूरा शेड्यूलिंग करेंगे कैसे तो फिर ये हमने पढ़ा क्यों पढ़ा सिर्फ इसलिए कि ये एक
हमें अंडरस्टैंडिंग दे सके एक स्टैंडर्ड हमें समझ आए कि यार अगर शॉर्टेस्ट ऑफ फर्स्ट में एवरेज वेटिंग टाइम इतना आ रहा
है ना तो ऑब् वियस इस आप बीट तो नहीं कर सकते बट कोशिश करिए इसके पास जाने की दूसरा एक आईडिया जरूर समझ आया जब बाद में
हम चारों पांचों एल्गोरिथम पढ़ लेंगे ना ें समझ आएगा लॉन्ग रन में जैसे राउंड रॉबिन है वो कुछ हद तक नॉट एगजैक्टली बट
कुछ हद तक कोशिश यही करता है कि छोटी जॉब्स पहले कंप्लीट हो जाए तो कुछ लोग इसको सिमुलेटर की कोशिश करेंगे बट यस
प्योर इंप्लीमेंटेशन ऑफ शॉर्टेस्ट जॉब फर्स्ट इज नॉट पॉसिबल वो पॉसिबल नहीं है यस तो आई होप इतनी बात आपको समझ आई अब
चलते हैं अगले एल्गोरिथम के तरफ जिसका नाम है प्रायोरिटी एल्गोरिथम यह मजेदार क्यों लगता है मेरे को एक्चुअली हर एल्गोरिदम
प्रायोरिटी एल्गोरिथम ही होता है बस पॉइंट है कि आप प्रायोरिटी एलोकेट कैसे करते हैं फर्स्ट कम फर्स्ट सर में हमने क्या बोला
हमने बोला जो पह पहले आएगा उसको पहले एग्जीक्यूट करेंगे तो एक्चुअली यही हो गया ना जिसका अराइवल टाइम कम है उसकी
प्रायोरिटी ज्यादा है अगला शॉर्टेज जो फर्स्ट था उसमें क्या बोला जिसका टाइम रिक्वायरमेंट कम है जिसका बस टाइम
रिक्वायरमेंट कम है वो पहले रन होगा तो वो भी एक तरह का प्रायोरिटी हो गया ये मेरे को अच्छा क्यों लगता है प्रायोरिटी
शेड्यूलिंग बिकॉज़ यहां पे तो वो सामने से बोल देता है इसका प्रायोरिटी ये है तो मैं प्रायोरिटी के हिसाब से रन करूंगा अगेन
लॉजिकल रिक्वायरमेंट क्या है सिस्टम के अंदर जैसा आप देख सकते हैं इधर इतना ट्रैफिक जाम लगा है इधर यू सी अ
प्रायोरिटी प्रोसेस सो आईडिया क्या है सर सिस्टम के अंदर कुछ प्रोसेस ऑपरेटिंग सिस्टम प्रोसेस हो सकते हैं जिनका
एग्जीक्यूशन सिस्टम के सर्वाइवल के लिए बहुत जरूरी है तो अभी तक जो भी दो एल्गोरिथम हमने पढ़े वहां इस तरह का कोई
प्रोविजन नहीं है कि अगर किसी प्रोसेस को प्रायोरिटी बेसिस पे रन करना हो तो कैसे करेंगे है ना उसका कोई आइडिया नहीं है तो
प्रायोरिटी उसका आईडिया है अगेन यहां दोनों वेरिएंट पॉसिबल है प्रिमिटिव एंड नॉन प्रिमिटिव तो मुझे ऐसा लगता है अगेन
लेट मी गो डायरेक्टली इन टू दन आईडिया क्वेश्चन सॉल्व करता हूं पूरी बात समझा डालता हूं दोनों तरह से सॉल्व करेंगे है
ना पहले अगेन नॉन प्रिमिटिव फिर प्रिमिटिव दूसरी बात अगेन याद दिला दूं कि प्रायोरिटी नंबर लिखे होंगे बट यू नो छोटा
नंबर बड़ी प्रायोरिटी है कि बड़ा नंबर नोबडी नोज क्वेश्चन में दिल मेंशन जैसे यहां मैं क्लियर कट आपको बता रहा हूं ऐसे
डिफॉल्ट केस मान के मत जाइएगा क्वेश्चन गलत करके आओगे डिफॉल्ट गस कुछ नहीं है यहां पे तो मैं आपको अलग से बता रहा हूं
कि एट नंबर इज द हाई प्रायोरिटी है ना ये बात क्लियर रखना तो छोटा नंबर छोटी प्रायोरिटी मेरे एग्जांपल में कोई और
एग्जांपल बनेगा उसमें डिफरेंट केस भी ले सकता है पहले शुरू करते हैं नॉन प्रिमिटिव वर्जन अगेन टाइम्स जीरो पर मैं आपसे
पूछूंगा कितने प्रोसेस है मेरे पास वही वाला एग्जांपल है टाइम जीरो पर कोई प्रोसेस नहीं है तो मेरे को वेट करना
पड़ेगा वन तक तो रो से वन तक यहां पर देखिए कुछ भी शेड्यूल नहीं होगा एट टाइम वन पहली प्रोसेस आई अब अगेन प्रायोरिटी
देखूं क्या नहीं क्योंकि आपको मैंने पहले समझाया कोई भी शेड्यूलिंग एल्गोरिथम तब चाहिए जब मल्टीपल प्रोसेसेस में डिसीजन
लेना हो अभी यहां प्रोसेस ही एक है तो क्या आप करोगे क्या मैं करूंगा उठा के रन करता हूं सर तो p न को मैं रन करूंगा और
क्योंकि नॉन प्रिमिटिव वर्जन है पूरा बस टाइम आपका कंप्लीट करूंगा तो p नॉ जो है वो वन से लेके फ तक प्रोसेस p नॉ
अनइंटरप्टेड चलने वाली है मेक सेंस एट टाइम फाइव जब पी नो बाहर जा रहा है मैं देख रहा हूं लगभग सारे प्रोसेस आ चुके हैं
अब गेम चलेगा सर प्रायोरिटी के बेस पे तो जरा मुझे बताइए इन सब में हाईएस्ट प्रायोरिटी किसका है फिलहाल है प्रोसेस p3
का बस टाइम अराइवल टाइम जाने दो बस ये बताओ प्रायोरिटी क्या है रिक्वायरमेंट क्या है फाइव यूनिट्स है सर सबसे पहले
आपकी रिक्वायरमेंट हम सेटिस्फाई करेंगे तो 5 प् 5 हो गया 10 और यह p3 द प्रोसेस विथ द हाईएस्ट प्रायोरिटी पहले रन होगा 8 के
बाद अगला नंबर नजर आ रहा है सेन रिक्वायरमेंट है थ्री यूनिट्स का नाम है टू तो प्रोसेस p2 ्र यूनिट रिक्वायरमेंट
है ना 10 प् 3 13 तक चलेगा अगला नंबर फिलहाल मेरे को नजर आ रहा है प्रायोरिटी सिक्स दो यूनिट का रिक्वायरमेंट है नाम है
p5 p5 यस ओके तो दो यूनिट है ना 13 प् 2 हो गया 15 नाउ दिस गोज एकट नाउ य सी जज अ क्लैश इन द प्रायोरिटी तो प्रायोरिटी में
क्लैश है तो टाई कैसे ब्रेक करेंगे अराइवल से कर लेते हैं तो इधर फाइव है इधर फाइव है अभी इधर थ्री है इधर टू है इधर थ्री है
तो यह सीनियर है इसको पहले रन करता हूं पहले आया था कुछ लोग बोलेंगे सर अराइवल टाइम में भी क्लैश हो तो भाई जो तुम्हारा
मन है वो पहले कर लो फिर क्या आप करोगे क्या मैं करूंगा फिलहाल क्लेरिटी है p1 पहले रन होगा दो यूनिट का रिक्वायरमेंट है
p1 तो 5 + 2 हो गया 17 दिस गोज आउट एंड नाउ वी हैव अ प्रोसेस जिसका सिर्फ एक यूनिट का बस रिक्वायरमेंट है p4 लेकिन
नंबर बाद में आए क्योंकि प्रायोरिटी इसका वीक था है ना तो ये चलेगा सबसे बाद में p4 रिक्वायरमेंट है ओनली वन यूनिट का तो 18
तक ये पूरी प्रोसेस कंप्लीट होगी है ना अब ये पूरा काम हमने कंप्लीट कर डाला है लेकिन हमने ध्यान रखा है कि कौन सा आईडिया
हमने यूज किया नॉन प्रिमिटिव प्रिमिटिव करेंगे तो आई थिंक इट विल बी मोर फन और एग्जाम पॉइंट ऑफ व्यू से भी कौन सा ज्यादा
इंपॉर्टेंट है प्रिमिटिव वर्जन शुरू करता हूं एक-एक करके बहुत शानदार तरह से ध्यान दीजिएगा सो अगेन लेट मी स्टार्ट विद टाइम
जीरो से वन तक तो हमें पता है कुछ रन होगा नहीं अब अगेन सबसे पहले जो प्रोसेस उठा के रन करो एक ही प्रोसेस अवेलेबल है प नो
चलेगा प्रायोरिटी कुछ भी हो तो जीरो से सॉरी वन से टू तक सिंगल यूनिट में चलाता हूं तो इसका टाइम कितना बचा बोलिए इसका
टाइम बचा थ्री है ना यहां तो कोई प्रॉब्लम नहीं है अब मुझे देखना पड़ेगा यहां पे कि कौन-कौन आया है यहां पे टाइम टू पे दो
प्रोसेस आए हैं और क्या किसी का प्रायोरिटी मेरे प्रायोरिटी से ज्यादा है ओबवियसली दो दोनों का ज्यादा कांटेक्ट
स्विच होगा 100% होगा पहले चलेगा ये p2 चलेगा जब तक अगला नहीं आ रहा अगला आ रहा है थ्री पे तो टू से 3 तक मैं p2 चलाता
हूं एक यूनिट p नॉ चला तो वो बचा है थ्री एक यूनिट अभी p2 चला है आई एम सॉरी एक यूनिट p2 चला है ना
यस नहीं टू पे तो भी मैं हुं ही ना टू पे कौन चलेगा तो टू पे भी p2 चलेगा हां ठीक है एक यूनिट p2 चलेगा सो नॉट दिस ये तो टू
ही रहेगा ये चला एक यूनिट तो ये बचा टू और अब टाइम थ्री पर आप देखेंगे तो यहां पर एंट्री लगाई है यू नो प्रायोरिटी सेवन के
भी बाप ने एट ने एंट्री लगा दी अब ये तो चलेगा े कोई रोक ही नहीं सकता और आगे टाइम देखने की भी जरूरत नहीं है फाइव यूनिट्स
का रिक्वायरमेंट है तो 8 तक 3 + 5 इ 8 p3 चलेगा विदाउट एनी कंफ्यूजन और आई थिंक जब तक ये बाहर जाएगा मेरे लिए गेम आसान हो
गया क्योंकि एवरी बडी इज ऑलरेडी कम अभी कौन पेंडिंग है सेवन वाला है क्या सेवन वाला पेंडिंग है दो यूनिट का रिक्वायरमेंट
है तो 8 प् 2 इज गोइंग टू बी 10 8 प् 2 इज गोइंग टू बी 10 एंड नाउ दिस इज लाइक p2 यह
बाहर होगा नाउ एट टाइम 10 दोबारा से देखिए अभी बताइए कौन हाईएस्ट प्रायोरिटी पेंडिंग है सिक्स पेंडिंग है सर दो यूनिट का
रिक्वायरमेंट है नाम है p5 तो 12 तक इसको चलाइए अब बताइए फाइव के दो पेंडिंग है बस टाइम मत देखिए क्लैश रिजॉल्व करते हैं
अराइवल टाइम से पहले p1 को रन करेंगे टू यूनिट्स का रिक्वायरमेंट पेंडिंग है तो ये 14 तक य भाई साहब चले अब बताइए कौन
पेंडिंग है 14 पे 14 पे 14 पे फिलहाल ये पेंडिंग है ना वन यूनिट रिक्वायरमेंट है तो 14 + 1 इज गोइंग टू बी 15 ये प्रोसेस
p4 यहां से जाता है बाहर सब हो चुके है थ्री यूनिट का रिक्वायरमेंट पेंडिंग है प्रोसेस p0 का ये देख रहे हैं एंडिंग सेम
पे होगा कोई फर्क नहीं पड़ता ो दैट इज हाउ प्रिमिटिव प्रायोरिटी शेड्यूलिंग वर्क्स तो आई थिंक पूरा आईडिया प्रायोरिटी का
आपको समझ आया होगा अप्रोच क्या है यहां मैं किसी पैरामीटर के लिए नहीं कर रहा मैं प्रायोरिटी के हिसाब से रन कर रहा हूं
मेरे को वेटिंग टाइम से या किसी और चीज से रिस्पांस टाइम से अ थ्रू पुट से कोई लेना देना सीपीयू यूटिलाइजेशन से कोई लेना देना
नहीं है मेरा पॉइंट है कि जो प्रायोरिटी प्रोसेस है पहले रन हो प्रिमिटिव नॉन प्रिमिटिव दोनों चीज मैंने आपको बताया
एडवांटेज सिस्टम को सपोर्ट करेगा फैसिलिटेट करेगा जो इंपॉर्टेंट प्रोसेस हैं उनको रन करने के लिए परमिट करेगा
डिसएडवांटेज अगेन स्टार्वेशन देखिए जब भी कोई स्पेशल क्राइटेरिया होगा कोई ना कोई स्टार्पेपर जिनका प्रायोरिटी कम है वो
धीरे-धीरे स्टार्वेशन में जाएंगे बड़ा इंपॉर्टेंट पॉइंट है तो यहां पे स्टार्वेशन है यस अब इसको रिजॉल्व कैसे
करें एक बड़ा मजेदार आईडिया है जिसको हम बोलते हैं एजिंग जैसे रियल लाइफ में होता है ना उम्र बढ़ने के साथ हम आदमी की
रेस्पेक्ट करने लगते हैं है ना किसी के पास पैसा है इसलिए रेस्पेक्ट कर रहे किसी के पास नॉलेज है इसलिए रेस्पेक्ट कर ो
किसी के पास हेल्थ है इसलिए रेस्पेक्ट कर रहे किसी के पास एज है इसलिए भी रेस्पेक्ट करता है पैर छूते है ना अपन सेम आईडिया है
लॉजिक क्या है जैसे-जैसे किसी प्रोसेस का वेटिंग टाइम बढ़ता जाए आप धीरे-धीरे उसकी प्रायोरिटी बढ़ाते जाए तो जैसे बोलते हैं
देर है बट अंधेर नहीं है तो होगा ये भले ही कोई प्रोसेस बहुत कम प्रायोरिटी से स्टार्ट करें बट जैसे-जैसे उसका वेटिंग
टाइम बढ़ता जाएगा मैं प्रायोरिटी बढ़ता बढ़ाता जाऊंगा तो कभी ना कभी तो यार उसका नंबर आ जाएगा ये छोटा सा आईडिया है अ
टेक्निक ऑफ ग्रेजुएटी ऑफ अ प्रोसेस दैट इज इन अ सिस्टम फॉर अ लॉन्ग टाइम है ना फॉर
एग्जांपल हर 10 मिनट में बढ़ाता जाता हूं सो दैट इज कॉल्ड एजिंग इससे प्रायरिटी सॉल्व हो जाएगा डन अभी बात करेंगे राउंड
रॉबिन के बारे में तो राउंड रॉबिन अगेन एक बहुत कमाल का एल्गोरिथम है बिल्कुल डिफरेंट आईडिया है इसका आईडिया क्या है
देखिए ये डिजाइंड है टाइम शेयरिंग सिस्टम्स के लिए टाइम शेयरिंग हमने समझा था एक्सटेंशन ऑफ मल्टी प्रोग्रामिंग जहां
पर आईडिया ये नहीं कि एक प्रोसेस को कंप्लीट किया जाए आईडिया ये है कि बहुत सारी प्रोसेस के बीच में इन अ सर्कुलर
फैशन यू नो टाइम शेयर किया जाए सीपीयू का मतलब हो सकता है बहुत सारे यूजर हो तो हर यूजर को थोड़ा-थोड़ा थोड़ा-थोड़ा टाइम अगर
हम एलोकेट करें दिस आइडिया इज़ कॉल्ड राउंड ड्रॉप इन तो ये बिल्कुल वही बात कर रहा है मैंने सारे पॉइंट बहुत अच्छे से
मेंशन किया डिजाइन फॉर टाइम शेयरिंग सिस्टम वेर इट इज नॉट द आइडिया टू कंप्लीट वन प्रोसेस देन स्टार्ट अनदर बट बी
रिस्पांसिस ये गोलगप्पे वाले भैया वाला अप्रोच है धीरे-धीरे सबको रिस्पांस करना है सीपीयू शेड्यूलर गो अराउंड द रेडी क्यू
एक सर्कुलर क्यू है एलोकेटिंग थोड़ा-थोड़ा टाइम हम देते हैं जिसको हम बोलते हैं मैक्सिमम टाइम इज वन टाइम क्वांटम या तो
उस टाइम क्वांटम के अंदर प्रोसेस कंप्लीट हो जाएगी पॉइंट नंबर वन अगर नहीं होती है तो उसके बाद मैं फोर्सफुली कांटेक्ट स्विच
करूंगा बोलूंगा पहले बाकी सबका नंबर आने दो फिर दोबारा से तुमको एग्जीक्यूट करूंगा और ऐसे सर्कुलर फैशन में मान लो एक-एक
रोटी सबको देते जाते हैं तो अगर किसी को 10 रोटी खानी है भाई वेट करना पड़ेगा पहले एक मिलेगी फिर सबको एक-एक मिलेगी अगर कुछ
लोगों का हो सकता है एक रोटी मन भर जाए वो बाहर चले जाएंगे जो नहीं बन जाएंगे फिर सबको एकएक मिलेगी जिनका दो वाला होगा वो
बाहर चले जाएंगे इस तरह मैं सर्कुलर फैशन में एलोकेट करता जाऊंगा बाकी सारे पॉइंट्स यहां प मैंने मेंशन किए हुए हैं आई विल
डायरेक्टली गो इन टू द आईडिया क्वेश्चन सॉल्व करके दिखाता हूं मजा आ जाएगा तो एक क्वेश्चन हमने लिया है एंड फॉर दिस
क्वेश्चन लेट मी एज्यूम सपोज द टाइम क्वांटम बीटू यूनिट्स यस तो यहां पर आपको अप्रोच समझाता हूं एक क्यू रन टाइम प
मेंटेन करो उससे इस क्वेश्चन को सॉल्व करना बहुत आसान है अदर वाइज इसमें बहुत सारे कंफ्यूजन हो जाते हैं ट्रस्ट मी तो
आई विल स्टार्ट विद टाइम जीरो टाइम जीरो पे कितनी प्रोसेस है टाइम जीरो पे एक ही प्रोसेस है मैं ऐसे मान लेता हूं वो लाइन
में खड़ी थी प्रोसेस मैंने उसे पिक कर लिया टाइम जीरो पे कितना रिक्वायरमेंट है फोर बट मैं फोर तो दूंगा नहीं मैं एक बार
में टू दूंगा तो मैं जीरो से टू तक किसको चलाऊंगा प्रोसे p2 को अब यहां बड़ा कांसेप्चुअल बात है बच्चे पता है क्या
करते हैं उठा के सबका एक सर्कुलर क्यू बना देते हैं भाई अराइवल टाइम भी तो इंपॉर्टेंट है तो ध्यान से देखना एट टाइम
टू p नॉ आया q से बाहर और जब वो बाहर आया तो वो क्या देखता है अराइवल टाइम वन p1 आ चुका था लाइन में p2 का अराइवल टाइम टू है
मान लेते हैं p2 भी लाइन में आ चुका था बट मजे की बात है अभी p3 p4 और p5 नहीं आए थे तो p न दोबारा आके लाइन में लग जाएगा ये
गेम है ये अगर आप समझ समझ ग तो राउंड रोबिन का कोई न्यूमेरिकल गलत नहीं करके आओगे आर यू गेटिंग इट अभी ये तीन नहीं आए
ना तो फिर उससे पहले दोबारा आ के लाइन में लग गया पहले खेलने आया था इसके ज्यादा नंबर आ रहा है फेयर इनफ दो यूनिट रन कर
चुका हूं दो बचेगा अगला नंबर है p1 का रिक्वायरमेंट है फाइव का वो दे नहीं पाऊंगा मैक्सिमम दे सकता हूं दो यूनिट तो
p1 चलेगा दो यूनिट के साथ कहां तक थ्री तक चला यस और सॉरी थ्री बचा जब ये बाहर आया तो टाइम हो चुका था फर तब तक अब आप नोटिस
करिए तब तक p3 आ चुका है p4 हो आ चुका है बट p5 अभी भी नहीं आया तो p5 से पहले p1 भी दोबारा लाइन में आके लग गया अगला नंबर
p2 का नाउ फॉर योर सरप्राइज दो यूनिट का टाइम क्वांटम था दो ही मैं दे रहा हूं तो यह अभी पहली इटरेशन में बाहर हो जाएगा
दोबारा क्यू मैं आक एंटर नहीं करेगा है ना सिक्स हो चुका है तो मैं यहां पे क्य भी मेंटेन करता रहता हूं कि p5 का भी अराइवल
हो चुका है अगला नंबर दोबारा से आ गया p न का अभी पन भी आई थिंक दोबारा एंट्री नहीं लेगा एक बार पहले रन कर चुका था दो यूनिट
पेंडिंग था वो अ भी सेटिस्फाई हो जाएगा तो ये लीजिए p0 भी बाहर हो गया अगला नंबर है p3 का अब यहां देखिए इंपॉर्टेंट केस टाइम
क्वांटम दो यूनिट का है लेकिन इसका रिक्वायरमेंट वन है तो वन ही चलेगा ऐसा नहीं जबरदस्ती दो यूनिट देंगे ही देंगे तो
नाइन तक p3 चला और p3 भी हो गया बाहर फाइनली p4 का नंबर आया है पहली बार नंबर आया अ सिक्स यूनिट्स का इसका रिक्वायरमेंट
है तो एक बार में तो दो यूनिट चल पाएगा तो फर बचेगा 9 + 2 हो जाएगा 11 और यह p4 और यह p4 दोबारा q में एंट्री लेगा यस अगला
नंबर नोटिस करिए p1 का है 3 यूनिट्स का रिक्वायरमेंट है अगेन मैं वन यूनिट बचेगा दो यूनिट दे पाऊंगा तो 11 से 13 तक फर्द
चला p1 और p1 भी दोबारा क्यू में एंट्री लेते हुए मुझे नजर आ रहा है आगे बढ़ते हैं पहली बार मौका मिला p5 को थ्री यूनिट का
रिक्वायरमेंट है वन बचेगा तो दो यूनिट मिलेगा तो 13 + 2 इ 15 और यह कहानी हो गई p5 की यह भी q में ऐसा q से मेंटेन करोगे
कभी गलती नहीं होगी यस फाइनली मेरे ख्याल से अब आखिरी नंबर है नहीं आखिरी नंबर नहीं है p4 भी दोबारा एंट्री लेगा दो यूनिट
पेंडिंग रहेगा तो 15 + 2 17 p4 भी दोबारा एंट्री लेते नजर आ रहा है देन p1 सिंगल यूनिट रिक्वायरमेंट है यहां से जाएगा बाहर
तो 17 + 1 इज 18 p p1 माफ कीजिएगा p1 हो गया बाहर देन p5 सिंगल यूनिट रिक्वायरमेंट पेंडिंग है तो 18 + 1
p5 यह बाहर हो गया 19 एंड आखिरी नंबर में बाहर होगा p4 दो यूनिट का रिक्वायरमेंट है 19 + 2 इज 21 दैट इज p4 तो राउंड रॉबिन
कैसे सर्कुलर क्यू ये सर्कुलर क्यू था कैसे सर्कुलर क्यू मेंटेन करके पूरा पैटर्न सॉल्व किया पूरा मैकेनिज्म एकदम
शानदार तरीके से समझ आया होगा कंप्लीशन टाइम ये तीनों कॉलम भरना मैंने पहले से सिखाया तो हर केस में आप सिमिलर तरह से भर
के एवरेज वेटिंग टाइम वो सब निकाल सकते हो कंक्लूजन द आईडिया राउंड रॉबिन सबसे शानदार काम करता है रिस्पांस टाइम पे
रिस्पांस टाइम क्या पहली बार जब हम रिस्पांस करते हैं तो क्योंकि यह कांटेक्ट स्विच करके जल्दी-जल्दी सबको रिस्पांस
करता है तो रिस्पांस टाइम की टर्म्स में तो ये शानदार काम करता है राउंड रॉबन कमिंग टू द नेक्स्ट आइडिया जैसे हमने बोला
टाइम शेयरिंग सिस्टम है लॉन्ग रन में कौन से प्रोसेस जल्दी बाहर हुए जिनका टाइम रिक्वायरमेंट कम था कि
ज्यादा था जिनका कम था मैं नहीं कह रहा पोरली वो है लेकिन स्टिल कम वाले जल्दी बाहर हुए ज्यादा वाले कुछ समय के बाद बाहर
हुए तो काइंड ऑफ इंप्लीमेंटेशन है नाउ अगेन यहां पर भी अगर शॉर्टेज ऑफस का इंप्लीमेंटेशन है तो बड़ी प्रोसेस र्व
करेंगी इस पूरे एल्गोरिथम का हाई लेवल इंपॉर्टेंस है टाइम क्वांटम पे अगर टाइम क्वांटम बहुत बड़ा हो जाएगा तो रिस्पांस
टाइम पुअर होगा यह काइंड ऑफ फस कम फस की तरह बिहेव करने लगेगा अगर टाइम क्वांटम बहुत कम कर देंगे तो रिस्पांस टाइम अच्छा
मिलेगा बट बहुत सारा समय वेस्ट होगा बार-बार कांटेक्ट स्विच करने में तो द सक्सेस ऑफ राउंड रॉबिन डिपेंड्स हैवली ऑन
द आईडिया ऑफ टाइम क्वांटम टाइम क्वांटम अच्छे से चूज करेंगे तो बढ़िया काम करेगा एंड लास्ट प्रायोरिटी का कोई प्रायोरिटी य
है भी नहीं भाई टाइम शेयरिंग के लिए बनाया तो प्रायोरिटी की कोई बात यहां पर नहीं करेंगे यस आई थिंक यह बात समझ आ गई अब
कंक्लूजन हमने पढ़े है ना श टेस्ट जब फर्स्ट पोरली तो इंप्लीमेंटेबल ही नहीं है लेकिन एफसीएफएस पढ़ा प्रायोरिटी पढ़ा
राउंड रॉबिन पढ़ा बताओ कौन सा अच्छा कौन सा खराब है मतलब बताओ विज में र्सिटी एग्जाम के लिए इंपॉर्टेंट है मैंने
इन परे डायरेक्ट क्वेश्चन देखे हैं लेकिन बच्चा घबरा जाता है न्यूमेरिकल यहां आता नहीं है दो तीन थोरेट्स ये तो आईडिया है
मल्टीलेवल आईडिया है मल्टीलेवल क्यू शेड्यूलिंग तो मल्टी लेवल क्यू शेड्यूलिंग क्या होता है
और कैसे इसकी लॉजिस है आपको समझाता हूं यहां पर हम क्या करते हैं इंस्टेड ऑफ हैविंग अ सिंगल रेडी क्यू ना वी मेंटेन
मल्टीपल रेडी क्यू तो जैसे ही कोई प्रोसेस आएगा क् सबका रिक्वायरमेंट अलग-अलग है उनको उसी हिसाब से मैनेज करते हैं
सिस्टम प्रोसेस जो हाई रिक्वायरमेंट होगा प्रायोरिटी का जिनको जल्दी रन करना है उनको एक रेडी क्यू में मेंटेन करते हैं
इंटरेक्ट प्रोसेस जिनको सिस्टम में बने रहना है बार-बार बार-बार इनपुट आउटपुट करना पड़ेगा इस तरह का रिक्वायरमेंट है एक
रिडिक्यूल में मेंटेन करेंगे बैच प्रोसेस कोई अर्जेंसी नहीं है कोई फाइल कॉपी प लगा हुआ है कुछ अपग्रेडेशन चल रहा है
बैकग्राउंड में चल सकता है उनको अलग कर लेंगे और होगा ये अब क्योंकि डिफरेंट डिफरेंट हमारी यू नो रिडी क्यूज है जिनका
अलग-अलग रिक्वायरमेंट्स है तो व्हाट वी कैन डू इन एव्री रिडी क्यू वी कैन हैव अ डिफरेंट एल्गोरिथम फॉर एग्जांपल आप अंदाजा
भी लगा पा रहे होंगे हियर कैन आई यूज़ द प्रायोरिटी वन क्योंकि सबसे इंपॉर्टेंट है अ सिस्टम प्रोसेस है इंटरेक्ट है बार-बार
सबसे बात करनी है व्हाई कांट वी यूज़ राउंड रॉबिन बैच है बैकग्राउंड में चलता रहेगा एफसीएफएस लगा दो है ना तो इस तरह का
एक आईडिया मैच करता है जहां पर हर किसी को हम एक साथ मेंटेन करते हैं मजे की बात है मैं दो पॉइंट मेंशन कर रहा हूं एक तो इन
सबके अंदर एक इनके बीच में तो लगाना पड़ेगा मान लीजिए इनके बीच में राउंड ड्रॉपिन लगा दो लाइक एन एल्गोरिथम इनसाइड
अ क्यू एंड एल्गोरिथम बिटवीन अ क्यू तो मैं बोल य रहा हूं कि एक टाइम इसको दो एक टाइम इसको दो एक टाइम इसको दो उसमें भी
आपको मन कर रहा है चेंज कर लो सपोज आई विल से अ काइंड ऑफ अ हाइब्रिड राउंड रोबिन जहां पर लेवल वन को चार यूनिट मिलेगा इसको
दो यूनिट मिलेगा इसको वन यूनिट मिलेगा तो कुछ बीच का रास्ता निकाला जा सकता है कितने लेवल होंगे रिडी क्यूस कितनी होंगी
हर के हर रिडिक्यूल के अंदर कौन सा एल्गोरिदम होगा डी क्य के बीच में आपस में कौन सा एल्गोरिदम होगा यह सब चीज
सब्जेक्टिव है बट यह मल्टीलेवल क्यू शेड्यूलिंग यह बताने का समझाने का बहुत अच्छा तरीका है कि इन जनरल ऑपरेटिंग
सिस्टम्स कैसे यह सारे के सारे प्रोसेस को सपोर्ट कर रहे होते हैं बिकॉज दे आर काइंड ऑफ यूजिंग मिक्सचर ऑफ ऑल ऑफ देम यस बाकी
सारे पॉइंट मैंने बहुत अच्छे से मेंशन किए यू कैन जस्ट कॉपी देम डाउन नोट देम डाउन एंड यू राइट देम इन द सेमेस्टर एग्जाम्स
नाउ लास्ट टॉपिक इस यूनिट का मल्टीलेवल फीडबैक क्यू शेड्यूलिंग तो ये एक थोड़ा सा मॉडिफाइड आईडिया है लॉजिक समझिए यहां पर
हमें ना पहले से डिवीजन करने की जरूरत नहीं पड़ती तो जैसे ही कोई प्रोसेस आएगा सबसे पहले वो एक ही लेवल पे जाएगा देयर यू
सी अकाउंट ऑफ राउंड रॉबिन आईडिया काइंड ऑफ जिसका टाइम क्वांटम है एट यूनिट्स अब अगर आपका रिक्वायरमेंट एट यूनिट या उससे कम है
तो आप यहीं से बाहर चले जाओगे अगर नहीं एट से ज्यादा चाहिए तो मैं आपको दोबारा स्क्यू में एंट्री नहीं दूंगा देन यू विल
गो टू द नेक्स्ट लेवल इसका टाइम क्वांटम है 16 यूनिट 8 + 16 24 अगर 24 तक का रिक्वायरमेंट है यहीं से एग्जिट यहां भी
काम नहीं चलेगा यू विल गो डाउन और लास्ट लेवल पर रखा है एफसीएफएस की बेटा अब तो तेरे को करके ही भेजेंगे तो इस तरह का
आईडिया जहां पर थ्रू आउट द लाइफ लिखा मल्टी लेवल फीडबैक क्यू शेड्यूलिंग थ्रू आउट द लाइफ यू कैन यू नो मूव बिटवीन द
क्यूज अच्छा इसमें आप चाहो तो एजिंग का कंसेप्ट भी लगा लो अभी बहुत समय से एफसीएफएस में बैठा हुआ नंबर नहीं आ रहा
मान लीजिए 10 मिनट वेट किया एक लेवल प्रमोट कर दो फिर नंबर नहीं आए एक लेवल प्रमोट कर दो तो इस तरह का हाइब्रिड
मॉडिफाइड आईडिया यूज कर सकते हैं ऑल इंपॉर्टेंट पॉइंट्स जो है वह सब मैंने यहां पे लिख के रखे हैं अगेन कितने क्यूज
होंगे क्या एल्गोरिथम होगा बिटवीन द क्यू इनसाइड द क्यू ये सब सब्जेक्टिव मैटर है तो ये दो एडिशनल पॉइंट और थे बाकी चार
एल्गोरिथम बहुत शानदार तरीके से हमने कंप्लीट किए तो दिस इज ऑल अबाउट द यू नो दिस आईडिया ऑफ सीपीयू शेड्यूलिंग तो अभी
बात करते हैं प्रोसेस सिंक्रोनाइजेशन के बारे में तो प्रोसेस सिंक्रोनाइजेशन बहुत जबरदस्त चैप्टर है मैं जल्दी से पहले
समझाता हूं कि क्या प्रॉब्लम है और किस तरह के क्वेश्चन उसके यहां से एक्सपेक्ट किए जाते हैं एक-एक करके डिटेल में बात कर
करेंगे तो देखिए आईडिया क्या है मल्टी प्रोग्रामिंग ऑपरेटिंग सिस्टम है किसी भी इंस्टेंस प बहुत सारी प्रोसेस होंगी जो
रिसोर्सेस के लिए कंपीट करती हैं बट इस सारे सिनेरियो में कभी-कभी इनकंसिस्टेंसी हो सकती है जब इतने सारे लोग एक ही टाइम
पे सेम डाटा एक्सेस करने की कोशिश करेंगे तो सोचिए क्लैश हो सकता है एक छोटा सा एग्जांपल कोट करता हूं यहां देखिए कोई
प्रोसेस है हमारे पास प जिसके अंदर सिर्फ तीन ही प्रोसेस क्या प्रोग्राम है है ना एक फंक्शन है जिसके अंदर तीन ही
इंस्ट्रक्शन लिखे हुए हैं रीड i i = i + 1 राइट आए तो मानो पहले वैल्यू को रीड करेगा फिर जो भी वैल्यू होगी + व करेगा एंड देन
प्व वन करने के बाद राइट करेगा फॉर एग्जांपल मान लेते हैं कि ओरिजनली लेट मी से i का वैल्यू क्या है 10 मान लेता हूं
सो लेट मी से ओरिजनली i का वैल्यू 10 है अब हमने पहली बार इसको रन करना स्टार्ट किया और जैसे हमने पहले भी समझाया जैसे ही
हम प्रोसेस को रन करते हैं क्या होता है प्रोग्राम को रन करते हैं एक प्रोसेस बन जाता है तो बन गया प्रोसेस p1 रन करना
स्टार्ट किया तो बताओ क्या रीड करेगा सर ये रीड करेगा 10 फिर i = i + 1 तो दिस इज गोइंग टू बी 11 और ये राइट करने ही वाला
था मान लेते हैं कि बीच में कॉन्टेक्ट स्विच हो गया अब तो सीपी शेड्यूलिंग पढ़ ली हमने कॉन्टेक्ट स्विच नहीं हो सकता
क्या हो सकता है सर अगर बीच में कॉन्टेक्ट स्विच हुआ तो अब बोलो क्या होगा सर कॉन्टेक्ट स्विच हुआ तो फिलहाल इसको यहीं
पे रोकना पड़ेगा राइट अपडेट नहीं होगा लेट मी से किसी दूसरे यू नो आईडिया ने आया और इसी कोड को दोबारा रन किया और एक नई
प्रोसेस जन्म लिया जिसका नाम है p2 हो सकता है ना आई कैन एग्जीक्यूट सेम कोड मल्टीपल टाइम और हर बार अलग-अलग प्रोसेस
बनेगी तो p2 बना लेकिन वैल्यू तो 10 ही है तो अब क्या हुआ देखो इसने वैल्यू रीड किया 10 इसने वैल्यू अपडेट किया i = i + 1 10 +
1 11 हुआ और मान लेते हैं कि इसने जाके राइट भी कर दिया तो जो ओरिजिनल वैल्यू 10 थी अब बोलो क्या हो गया अब सर वो वैल्यू
हो गया 11 बात समझ आती है अब जब p1 कंटिन्यू करेगा तो क्या वो शुरुआत से करेगा नहीं वो तो दो इंस्ट्रक्शन
एग्जीक्यूट कर चुका है तो वहीं से आगे करेगा और वो तो 11 कैलकुलेट कर चुका है सर तो 11 इ इ टू वो यहां पर जाके 11 को कायदे
से कट करके दोबारा 11 ही लिख देगा अब बोलो क्या हुआ यह कायदे से एक तीन लाइन का बेसिक सा कोड है इंक्रीमेंट करने के लिए
और हमने इस पे दो बार इंक्रीमेंट किया है तो जेनुइनली वैल्यू 10 से क्या हो जानी चाहिए थी 12 हो जानी चाहिए थी बट यहां पर
वैल्यू क्या हुआ 11 ही हुआ सो दैट इज अ वेरी सिंपलेस्ट एग्जांपल ऑफ एन इनकंसिस्टेंसी कि क्या हो सकता है और इस
सिनेरियो को हम क्या बोलते हैं दिस इज कॉल्ड रेस कंडीशन ये टर्म बड़ा इंपॉर्टेंट है पांच नंबर का क्वेश्चन डायरेक्ट इसी पे
पूछा जा सकता है पढ़ें एक बार क्या लिखा है रेस कंडीशन इज अ सिचुएशन इन व्हिच द आउटपुट ऑफ अ प्रोसेस डिपेंड्स ऑन द
एग्जीक्यूशन सीक्वेंस ऑफ द प्रोसेस जब आउटपुट एग्जैक्ट एग्जीक्यूशन ऑर्डर जो है उस परे डिपेंड करने लगे क्योंकि सोचिए अगर
मैं पहली प्रोसेस कंप्लीट होने देता उसके बाद दूसरी प्रोसेस चलाता तो रिजल्ट 11 आता कि 12 आता सर 100% उस केस में 12 आता बट
इस बार रिजल्ट क्या आ 11थ आउटपुट तो चेंज हो गया है एंड वी चेंज द ऑर्डर ऑफ़ एग्जीक्यूशन द डिफरेंट प्रोसेस विद
रिस्पेक्ट टू अदर प्रोसेस द आउटपुट मे चेंज तो ये सिनेरियो हुआ रेस कंडीशन याद रखिएगा व्हाट इज रेस कंडीशन जब ऑर्डर चेंज
करने से रिजल्ट चेंज होने लगे रेस कंडीशन कहलाता है और प्रोसेस सिंक्रोनाइजेशन क्या प्रॉब्लम हुआ बहुत सारी प्रोसेस हैं शेयर
डाटा पे काम करेंगे अब यहां पर आई कौन था शेड वेरिएबल था ना इसलिए प्रॉब्लम हो गया आगे बढ़ता हूं इससे पहले कि हम यू नो बहुत
सारे सॉल्यूशंस और बहुत सारे आइडियाज पे डिटेल में बात करें ये एक स्ट्रक्चर समझ लीजिए किसी भी प्रोसेस का इस पूरे चैप्टर
में ये स्ट्रक्चर हमारे साथ चलेगा हम क्या मान रहे हैं सपोज देर इज अ प्रोसेस p अब कोई भी प्रोसेस मैं वाइल टी इसलिए लगा रहा
हूं आपको समझाता हूं बेसिक स्ट्रक्चर मैं जब चाहूं जितनी बार चाहे रिपीट कर सकता हूं देखो कोई भी प्रोसेस अपने पूरे लाइफ
स्पैन में हमेशा तो शेयर्ड डाटा यू नो रन नहीं करेगा शेयर्ड डाटा पे काम नहीं करेगा तो कभी वो ऐसे डाटा पे काम कर सकता है जो
शेयर्ड ना हो और कभी वो ऐसे डटा पे काम करेगा जो शेयर्ड हो अगर मैं ऐसे डटा पे काम कर रहा हूं जो शेयर्ड नहीं है तो क्या
क्लैश होने का है ना इनकंसिस्टेंसी होने का कोई चांस है कोई चांस नहीं है चांस कब है जब शेयर्ड डाटा प काम करें उस सेक्शन
को आज के बाद हम बोलेंगे क्रिटिकल सेक्शन ये टर्म बड़ा इंपॉर्टेंट है बहुत लोग इसमें कंफ्यूज हो जाते हैं डेफिनेशन देखिए
वेयर अ प्रोसेस एक्सेस शेयर्ड रिसोर्सेस जब भी मैं शेयर्ड रिसोर्स पे शेयर्ड डाटा पे काम करूंगा तो मैं बड़ा ध्यान रखूंगा
कि यार किसी को गड़बड़ ना हो जाए किसी के साथ यू नो लड़ाई ना हो जाए अपनी तो इस सेक्शन को हम बोलेंगे क्रिटिकल सेक्शन
इनिशियल सेक्शन प्रोसेस अपने प्राइवेट डाटा पे प्राइवेट रिसोर्स प काम कर रहा है रिमाइंडर सेक्शन वो क्रिटिकल सेक्शन पे
काम कर कर चुका हम बाहर आ गए हैं है ना और ये एंट्री और एग्जिट सेक्शन क्या लिखा हुआ है आगे बात करेंगे क्रिटिकल सेक्शन बहुत
क्रिटिकल है हम नहीं चाहते जिसका जब मनाए तभी वो क्रिटिकल सेक्शन में चला जाए दो-चार चीजें चेक करेंगे क्या कोई और तो
अभी उस पर काम नहीं कर रहा एक बार में जाएंगे क्लैश तो नहीं होगा इसलिए एंट्री और एग्जिट हमने बना दिया है ये कायदे से
मान के चलिए सिक्योरिटी है क्रिटिकल सेक्शन की अपने लाइफ में क्या जरूरी है प्रोसेस एक ही बार क्रिटिकल सेक्शन में
जाए नहीं हो सकता है ना पूरे लाइफ में पहले थोड़ी देर शेयर डाटा एग्जीक्यूट किया फिर कुछ समय बाद फिर किया फिर कुछ समय बाद
फिद किया ऐसा हो सकता है इसीलिए हमने इसको वाइल टू यू नो लूप में रखा है कि मैं जब चाहे इसको रिपीट कर सकता हूं तो हो सकता
है मैं क्रिटिकल सेक्शन में एंटर करूं बाहर हो जाऊं कुछ समय के बाद फिर मुझे जरूरत पड़े फिर मैं अंदर जाऊं फिर बाहर हो
जाऊं ये प्रोसेस चलती रहेगी तो ये पूरा का पूरा पैटर्न आपको याद रखना है क्रिटिकल सेक्शन को कैसे सॉल्व करना है तो क्रिटिकल
सेक्शन प्रॉब्लम क्या हुआ पहले ये समझो क्रिटिकल सेक्शन इज दैट सेक्शन जहां पे मैं शेयर्ड डाटा को एक्सेस कर रहा हूं ये
तो बेसिक बात हो गई अब हमें क्या करना है हमें ऐसा सॉल्यूशन लिखना है एक क्रिटिकल सेक्शन प्रॉब्लम को सॉल्व करना है जहां पे
मल्टीपल प्रोसेस एक साथ शेयर्ड डाटा प काम कर सके या शेयर डाटा के साथ उसके ऊपर ऑपरेट कर सके और उनके कोलिजन उनके क्लैशेस
ना हो तो अभी बात करते हैं इस चीज पे कि क्रिटिकल सेक्शन प्रॉब्लम को सॉल्व करेंगे कैसे बट यहां पे एक और कहानी में ट्विस्ट
है ट्विस्ट क्या है ट्विस्ट है क्राइटेरियास मतलब यहां पर हमारे पास कुछ स्टैंडर्ड क्राइटेरियास हैं कुछ मान के
चलिए वो यू नो जैसे बोलते हैं चेक पॉइंट्स हैं कुछ मापदंड है जो पूरे होने ही चाहिए तो यहां यहां पर अभी मैं सॉल्यूशन की बात
नहीं कर रहा आपसे ये आ आईएसआई मार्क है जब तक कोई भी सॉल्यूशन ये क्राइटेरिया फुलफिल नहीं करता तब तक हम उसे वैलिड नहीं मानते
तो मुकाबला नि इसके की पहले हम डायरेक्टली सॉल्यूशन पढ़े पहले क्राइटेरिया समझ लेते हैं ताकि बाद में हम अच्छे से जज कर पाए
कि हमारे जो सॉल्यूशन है वैलिड है कि नहीं है है ना तो पहला जो इंपॉर्टेंट क्राइटेरिया है क्रिटिकल सेक्शन के लिए
बड़ा इंपॉर्टेंट है सर दैट इज म्यूचुअल एक्सक्लूजन अ वेरी सिंपल आईडिया इट सेज व्हाट नो टू प्रोसेस शुड बी प्रेजेंट
इनसाइड अ क्रिटिकल सेक्शन एट द सेम टाइम दैट इज ओनली वन प्रोसेस इज अलाउड टू क्रिटिकल सेक्शन एट एनी इंस्टेंस ऑफ टाइम
एंड दैट इज अ वेरी कॉमन सेंस थिंग भाई जब दो लोग होंगे एक ही टाइम पे होंगे शेयर डाटा को एक्सेस करने की कोशिश करेंगे तो
सर लड़ाई तो होगी होगी ना तो एक काम करते हैं लड़ाई की जड़ी खत्म कर देते हैं हम ये नहीं कह रहे कि आप करो मत प्रोसेस को भी
किसी शेयर्ड डाटा पे काम करना है तो करेगा हम बोल रहे हैं सेम टाइम पे मत करो तो आप कितना भी स्मार्ट सॉल्यूशन लिखो लेकिन अगर
आपके सॉल्यूशन में दो प्रोसेस एक साथ क्रिटिकल सेक्शन में आ गए तो हम मान लेंगे इनवैलिड है बिकॉज इट इज वेरी रिस्की इजेंट
इट तो व्हाट इज म्यूचुअल एक्सक्लूजन एक टाइम पे क्रिटिकल सेक्शन में एक ही प्रोसेस रहने वाली है बात खत्म सेकंड
प्रोग्रेस ये बड़ा स्मार्ट है इसको मैं समझा देता हूं इसमें सबसे ज्यादा कंफ्यूजन होता है प्रोग्रेस में बच्चों को
प्रोग्रेस क्या कहता है सिर्फ वही प्रोसेस क्रिटिकल सेक्शन में जाएगी या जाने के लिए कंपीट करेगी जो सच में क्रिटिकल सेक्शन
में जाना चाहती हो इंटरेस्टेड हो एक कॉमन सेंस आइडिया कभी-कभी क्या हो सकता है सर टोटल एन प्रोसेस है राउंड रॉबिन लगा दो ना
पहला जाएगा फिर दूसरा जाएगा फिर तीसरा जाएगा जब एन चले जाएंगे फिर से पहला शुरू हो जाएगा लेकिन अगर उसमें बीच में 10
प्रोसेस को जाना ही ना हो तो तो यह इनवैलिड है है ना इससे एफिशिएंसी प फर्क पड़ेगा तो प्रोग्रेस क्या कहता है सिर्फ
वही क्रिटिकल सेक्शन में जाए जो लिटरली जाना चाहता है जबरदस्ती किसी को नहीं भेजना है कुछ लोग ऐसा करेंगे आगे समझाऊ
आपको पढ़ लेता हूं नो इफ नो प्रोसेस इज एग्जीक्यूटिंग इन इट्स क्रिटिकल सेक्शन सम प्रोसेस विशेस टू एंटर द क्रिटिकल सेक्शन
अगर कोई जाना चाहता है देन ओनली दोस प्रोसेस दैट आर नॉट ए यूटिंग इन द रिमाइंडर सेक्शन कैन पार्टिसिपेट इन
डिसाइडिंग व्हिच विल एंड इन द क्रिटिकल सेक्शन बेसिकली रिमाइंडर सेक्शन की बात क्यों कर रहे हैं जो रिमाइंडर में है वो
जाना चाहता है कि नहीं जाना चाहता वो तो नहीं जाना चाहता तो ऐसे किसी प्रोसेस को हमको नहीं भेजना जो इंटरेस्टेड नहीं है यस
यानी के ओनली दोज प्रोसेस विल पार्टिसिपेट व्हिच एक्चुअली विशेस टू एंटर एक और इसमें एडिशनल पॉइंट ध्यान रखना है कुछ सॉल्यूशन
ओवर स्मार्ट खेलने के चक्कर में डेड लॉक लगा देते हैं तो अगर सिस्टम में डेड लॉक लगा तो भी हम मानेंगे प्रोसेस फेलर
प्रोग्रेस हमारा फेल हो गया यस एंड थर्ड एंड द लास्ट पॉइंट इज लाइक बाउंड वेटिंग इसका मतलब क्या है देयर एजिस्ट अ बाउंड और
अ लिमिट ऑन द नंबर ऑफ़ टाइम अ प्रोसेस इज़ अलाउड टू एंटर द क्रिटिकल सेक्शन एंड नो प्रोसेस शुड वेट
इनफाइनों चाहिए कि इनफा बाउंड वेट होना चाहिए फॉर एग्जांपल एक प्रोसेस है p24 सपोज वो कहता है मेरे को क्रिटिकल सेक्शन
में जाना है रिक्वेस्ट कर रहा है तो क्या इसके रिक्वेस्ट करने के बाद हो सकता है कोई दूसरा प्रोसेस पी 17 10000 बार
क्रिटिकल सेक्शन में जाके बाहर आ जाए नहीं आप मुझे टाइम बताएंगे या काउंट बताएंगे कि आपका फॉर एग्जांपल 15th नंबर आपका है तो
इतने न समय के अंदर आपका नंबर आ जाएगा कोई दूसरा प्रोसेस ऐसा नहीं जाते जा रहा है जाते जा रहा है इस बेचारे का नंबर ही नहीं
आ रहा तो जो हमारा वेट है वो वेट कैसा होना चाहिए बाउंड होना चाहिए अब इसमें एक पॉइंट और बता देता हूं इन तीन
क्राइटेरियास में जो पहले दो हैं ये डायरेक्ट क्वेश्चन पूछ लेता है म्यूचुअल एक्सक्लूजन एंड प्रोग्रेस ये हमारे हैं
मैंडेटरी टेरिया यानी कि अगर आपने यह ऊपर के दोनों क्राइटेरिया सेटिस्फाई करे म्यूचुअल एक्सजन और प्रोग्रेस तो मान
लेंगे आपका सॉल्यूशन वैलिड है कोई प्रॉब्लम नहीं जो थर्ड क्राइटेरिया है हमारा बांडेड वेट ये हमारा ऑप्शनल है
डिजायरेबल है अगर हो तो अच्छा अगर नहीं हो तो भी कोई बात नहीं है तो अगर कोई प्रोसेस सिर्फ दो क्राइटेरिया भी सेटिस्फाई कर दे
दो मतलब ऐसा नहीं नीचे के दो ऊपर वाले दोनों न म्यूचुअल एक्सक्लूजन और प्रोग्रेस तो हम बोलेंगे सॉल्यूशन वैलिड है यस ये एक
एडिशनल पॉइंट यही मैंने बताया यहां पे आपको बता दिया अब सॉल्यूशन पे आ जाते हैं कैसे सॉल्व करेंगे अभी सॉल्यूशन की बात
नहीं की थी आप समझ रहे हैं ना यह जो भी हमने पढ़ा तो सिर्फ क्राइटेरिया था अभी सॉल्यूशन पढ़ेंगे तो सॉल्यूशन में एक
आईडिया तो यह है कि हम यू नो पहले मुकाबल सिस्टम में कितनी प्रोसेस है सिस्टम में तो सर बहुत सारी प्रोसेस हो सकते हैं सपोज
करिए p1 से लेके pn4 सॉल्यूशन पे और यहां पर एक सॉल्यूशन है टर्न वेरी वेरिएबल का फ्लैक का पीटरसन
सॉल्यूशन या इसका एक और वेरिएंट है डेकर्स एल्गोरिथम मैं तीनों चारों की बात करूंगा बड़े पॉपुलर है कॉम्पिटेटिव एग्जाम में
सेमेस्टर्स में डायरेक्ट क्वेश्चन में पूछता है पांच नंबर का 10 नंबर का पहले इसके ऊपर बात करेंगे एंड देन हमारा जो
सीमा फर्स है साथ में जो क्लासिकल प्रॉब्लम है है ना प्रोड्यूसर कंज्यूमर बाउंडिंग बफर वो सब सॉल्व करेंगे एंड देन
मैं बात करूंगा टेस्ट एंड सेट की तो सबसे पहले बात करते हैं अभी टू प्रोसेस सॉल्यूशन के बारे में तो चलिए अभी टू
प्रोसेस सॉल्यूशन में जैसे मैंने बोला दो-तीन अलग-अलग आइडियाज है एक-एक के तीनों आईडिया डिस्कस करते हैं पहला आईडिया है
यूजिंग अ टर्न वेरिएबल दो प्रोसेस में सॉल्व करते हैं तो कैसे करते हैं कैसे आपस में सिंक्रोनाइज करते हैं एकएक करके देखिए
पूरा कोड हमने लिखा हुआ है क्या रिसोर्स हम यूज कर रहे हैं हमारे पास एक टर्न वेरिएबल है बुलियन नेचर का बुलियन नेचर का
तो दो ही वैल्यू उसके हो सकते हैं या तो जीरो या तो वन तो मान लीजिए मैं यहां पर लिख लेता हूं लेट मी से कोई भी वैल्यू से
स्टार्ट करते हैं रैंडम इनिला इज रैंडम तो लेट मी स्टार्ट विद जीरो अब आप देखो दो प्रोसेस है p न और p1 वाइल वन लिखा है
ताकि जब चाहे जितनी बार चाहे घूम सकते हैं और रन करके देखते हैं मान लेते हैं मैं पहली प्रोसेस चेक कर रहा हूं क्या अ यू नो
p नॉ अच्छा इफ टर्न इज नॉट इक्वल टू ज जीरो मजे की बात क्या इक्वल टू नहीं चेक करा नॉट इक्वल टू चेक कर रहा तो आप मुझे
बताओ फिलहाल टर्न की वैल्यू क्या है रो 0 इज नॉट इक्वल टू 0 कंडीशन ट्रू या कंडीशन फॉल्स कंडीशन फॉल्स कंडीशन फॉल्स होगा आप
लूप में रहेंगे कि लूप के बाहर आ जाएंगे आप लूप के बाहर आ जाएंगे और प्रोसेस p0 जो है वो बड़े आराम से देखिए पहुंच गया
क्रिटिकल सेक्शन में एक चीज जो नोटिस करने वाली है यह बाकी के जो इंस्ट्रक्शन है वाइल के अंदर नहीं लिखे हुए हैं यह वाइल
लूप दरअसल एक ट्रैप है आप देखिए वाइल के बाद ही सेमीकलन है तो इट इज लाइक जैसे वाइल लूप काम करता है ना मैं जाऊंगा मैं
कंडीशन चेक करूंगा कंडीशन अगर ट्रू होगी तो मैं बॉडी के पास जाऊंगा एंड देन आई गो बैक कंडीशन अगर फॉल्स होगी मैं आगे जाऊंगा
अगर मैं यहां से बॉडी हटा दूं तो देर यू सी नाउ अभी एक लूप बन जाएगा अब एक लूप बन जाएगा इजेंट इट तो वही यहां पर हो रहा है
तो खैर मैं लूप में नहीं फंसा मैं क्रिटिकल सेक्शन में हूं एक बार चेक कर लेते हैं अगर इस समय कंटेक स्विच हो भी
गया हो सकता है क्या सर कांटेक्ट स्विच तो कभी भी हो सकता है अगर इस समय कॉन्टेक्ट स्विच होता है तो मुझे बताएं क्या p1
क्रिटिकल सेक्शन में जा पाएगा ट्राई कर लेते हैं टर्न की वैल्यू जीरो है p1 आएगा आएगा आएगा 0 इज नॉट इक्वल टू 1 कंडीशन
ट्रू के कंडीशंस फॉल कंडीशन ट्रू और जब कंडीशन ट्रू होगी तो मुझे बताओ p1 इसी लूप में घूमता रहेगा कि क्रिटिकल सेक्शन में
जा पाएगा सर इसी लूप में घूमता रहेगा इजन इट मान लो कुछ कु समय के बाद p1 बेचारा यहां पर फंसा हुआ है कंट्रोल दोबारा p नॉ
के पास आता है क्रिटिकल सेक्शन एंजॉय करने के बाद p1 बाहर आता है बट यहां देखिए क्या कर रहा है टर्न इक्वल टू 1 अब जैसे ही ये
टर्न करेगा वन और सोचिए कंट्रोल दोबारा p1 को मिलेगा ये मैं एक और काम करके दिखाता हूं टर्न वन है लेट मी से रिमाइंडर सेक्शन
में गया घूम के वापस आया इसका मन है फिर दोबारा क्रिटिकल सेक्शन में जाना चाहता है बट बताओ जा पाएगा क्या टर्न की वैल्यू है
वन वन इज नॉट इक्वल टू 0 कंडीशन ट्रू अब ये यहां हां पर फस जाएगा इसका मतलब अब नंबर p1 का आएगा वन इज नॉट इक्वल टूव
कंडीशन फॉल्स p1 चला जाएगा क्रिटिकल सेक्शन के अंदर थोड़ा सा आप उसको स्टडी करेंगे तो आपको क्या समझेगा 100% यहां पर
म्यूचुअल एक्सक्लूजन है पहला मैंडेटरी क्राइटेरिया एक बार में दोनों प्रोसेस p न और p1 क्रिटिकल सेक्शन में नहीं जा पाएंगी
ये बात बिल्कुल तय है दूसरी बात लेकिन जो नोटिस करने वाली है यहां पर ना स्ट्रिक्ट अल्टरनेशन है जब आप नीचे जाते हैं टर्न कर
देते हैं वन यानी कि अब अगला नंबर आता है p1 का p1 जब नीचे जाता है टर्न करता है जीरो यानी कि अगला नंबर आता है किसका p न
का ये दोनों एक दूसरे को कैच कैच नंबर देते रहेंगे राउंड रॉबिन है p1 के बाद p न p न के बाद p1 फिर p न के बाद p1 फिर p1
के बाद p न इसे बोलते हैं स्ट्रिक्ट अल्टरनेशन और ध्यान से सोचेंगे ये प्रोग्रेस नहीं है क्यों इमेजिन करो हमने
तो यहां प्रोसेस से पूछा ही नहीं मान लो अगर p1 को क्रिटिकल सेक्शन में जाना ही ना हो सोचो ऐसा हो सकता है क्या हां हो तो
सकता है लेकिन उस केस में क्या p न जो है वह 10 चक्कर लगा पाएगा मेरे ख्याल से नहीं लगा पाएगा देखो ना कैसे लगाएगा जैसे ही
बाहर आएगा टर्न वन किया अब तो जबरदस्ती है कि p1 को जाना ही पड़ेगा p1 बाहर आएगा p नॉ को जाना पड़ेगा तो यहां पर जैसे हम बोल
रहे थे प्रोग्रेस जो सच में जाना चाहता है वह जाए जबरदस्ती ना हो यहां पर जबरदस्ती है यहां पे स्ट्रिक्ट अल्टरनेशन है इसका
मतलब यह सॉल्यूशन वैलिड नहीं है अ अजीब बात है आप सोचोगे वैलिड नहीं है तो पढ़ा क्यों पढ़ते हैं इसको आईडिया समझने के लिए
ताकि आगे जब सही आईडिया डेवलप करें तो क्लेरिटी हमको हो इस बात को ध्यान से दोबारा सुनिए मैं क्या बोल रहा हूं कि
यहां पर म्यूचुअल एक्सक्लूजन सेटिस्फाई किया कोई दिक्कत नहीं बट प्रोग्रेस फेल हो गया है और ये दोनों मैंडेटरी क्राइटेरिया
थे इसमें अगर एक भी फेल होता है तो सॉल्यूशन को हम फेल मान लेते हैं सो दैट इज अ रीजन यह काम नहीं करेगा इसी का एक
नेक्स्ट वेरिएंट है तो ये मैंने बता दिया दिस इज नॉट अ गुड सॉल्यूशन इसी के एक नेक्स्ट वेरिएंट है जहां पर हम सीखते हैं
कि या टर्न वाले कोड में हमने गलती क्या की हमने क्या गलती की हमने गलती यह की हमने प्रोसेस पूछा ही नहीं अपने मन से जब
बाहर निकल रहा है वो जीरो कर रहा है दूसरे वाला वन कर रहा है स्ट्रिक्ट अल्टरनेशन किया यहां पर देखिए हमने क्या किया है ऊपर
देखिए क्या लिखता हूं हियर वी यूज अ बुलियन एरे फ्लैग विथ टू सेल्स ईच ऑफ व्हिच इज इनिला टू फॉल्स तो मान लीजिए एक
एरे हमने बनाया फ्लैग अगेन बुलियन नेचर का है दो ही सेल है उसके अंदर एक सेल है प्रोसेस p0 का एक सेल है प्रोसेस p1 का और
इनिशियल वैल्यू नोटिस करिए दोनों के अंदर है फॉल्स अब यहां पर करना क्या है नोटिस करिए करना हमको ये है कि जब भी कोई
प्रोसेस देखे प नो को स्टडी कर लेते हैं इस बार रैंडम इनिश इज नहीं करना फॉल्स इनिश इज करना है जब भी किसी प्रोसेस को
क्रिटिकल सेक्शन में जाना है नोटिस करिए क्या करता है तो वो सबसे पहले फ्लैग ऑफ जीरो में ट्रू लिख रहा है मानो लक्सर बता
रहा है कि आई एम इंटरेस्टेड प्लीज मुझे जाने दो तो यहां पर देखिए ये वैल्यू हमने कर दिया ट्रू यस अब ये क्रिटिकल सेक्शन
में जाना चाहता है पर फिर देखिए कितना स्मार्ट है कितना अच्छा है वाइल फ्लैग वन और फिर वही सेमीकलन यानी कि यह ट्रैप बना
रहा है कह रहा है मैं जाना तो चाहता हूं बट क्या मेरा भाई p1 तो नहीं जाना चाहता क्या फ्लैग ऑफ वन में ट्रू तो नहीं है
सोचिए अगर फ्लैग ऑफ वन में ट्रू होता तो यही लूप करता रहता बट फिलहाल नहीं है फिलहाल सिर्फ यही यहां पे फॉल्स है कंडीशन
फॉल्स हुआ p नॉ बड़े आराम से पहुंच गया क्रिटिकल सेक्शन में एक बार ट्राई कर लेते हैं म्यूचुअल एक्सशन फेल तो नहीं होगा जब
p1 शुरू करेगा देखिए वो भी यही कर रहा है वो क्या कर रहा है फ्लैग ऑफ वन में ट्रू वो कह रहा है भैया मैं भी जाना चाहता तो
ट्रू मार्क कर दिया देन फ्लैग जीरो अगेन चेक कर रहा क्या मेरे भाई का फ्लैग ट्रू तो नहीं है ट्रू है ट्रू है तो मैं इसके
आगे नहीं जाऊंगा p1 यहीं पे वेट करता रहेगा और म्यूचुअल एक्सक्लूजन यहां पर मुझे वायलेट होता नजर नहीं आ रहा कुछ समय
के बाद सोच क्या होगा p न जब बाहर आएगा वो सबसे पहले फ्लैग ऑफ ज जीरो में फॉल्स करेगा यह बताने के लिए कि उसका मन भर गया
वो क्रिटिकल सेक्शन से बाहर आ गया और यह लो मैंने अपना फ्लैग उठा के फाल्स कर दिया और मान लो वो घूम रहा है रिमाइंडर सेक्शन
में इंटरसेक्शन में अब दोबारा इमेजिन करिए इस समय अगर कांटेक्ट स्विच होता है क्या अभी p1 को एंट्री मिलेगी 100% मिल जाएगी
क्योंकि यहां पर फ्लैग फॉल्स है तो फ्लैग ऑफ ़ इ इ ू फॉल्स एंड नाउ देर यू सी p1 वेरी क्लीयरली में एंटर इनटू द क्रिटिकल
सेक्शन मान रहे हैं तो म्यूचुअल एक्सक्लूजन जो है वो यहां पर 100% काम कर रहा है क्राइटेरिया सेटिस्फाई हो गया अगला
है प्रोग्रेस प्रोग्रेस अगर मैं आपको ध्यान से समझाऊं वो भी अच्छा काम करता है ऐसा लगेगा पहले स्टार्टिंग में स्टार्टिंग
में दोनों का फॉल्स से मान लीजिए मैं p1 का ट्रू कर देता हूं p नॉ का अब ये आया इसने ट्रू किया क्रिटिकल सेक्शन एंजॉय
किया क्योंकि मान लीजिए p1 का जो फ्लैग है वो फॉल्स है तो कोई प्रॉब्लम नहीं है फॉल्स हो गया बाहर आया एंजॉय किया आके
अपना फ्लैग फॉल्स किया मेरा पूछना यह है अगर मैं एक राउंड मार के दोबारा आऊं और फिर से अपना फ्लैग ट्रू कर लूं कोई
प्रॉब्लम होगा क्या आई डोंट थिंक कोई प्रॉब्लम है फिर से ट्रू करेगा भाई अभी भी इंटरेस्टेड नहीं है अगेन इट विल गो इन द
क्रिटिकल सेक्शन पहले जो टर्न वेरिएबल वाला सॉल्यूशन था ना वहां ऐसा नहीं हो रहा था नोटिस करो आप वहां पर क्या था p न के
बाद p1 p1 के बाद p नॉ बट यहां पर हमने इंप्रूवमेंट किया है अगर दूसरा प्रोसेस इंटरेस्टेड ही नहीं है अगर p1 इंटरेस्टेड
नहीं है तो अब p नॉ जब चाहे जितनी बार चाहे राउंड लगा सकता है जो कि रियलिटी में प्रोग्रेस है सिर्फ वही पार्टिसिपेट कर
रहा है जो जाना चाहता है बट कभी-कभी ओवर स्मार्ट खेलने के चक्कर में गलती हो जाती है कैसे नोटिस करिए प्रोग्रेस की एक
कंडीशन और थी क्या थी बताओ डेड लॉक नहीं लगना चाहिए अब इमेजिन करो स्टार्टिंग में दोनों का फ्लैग फॉल्स है कोई प्रॉब्लम
नहीं है p न ने एग्जीक्यूशन चालू किया फ्लैग ऑफ ज़ीरो में ट्रू मार्क कर दिया तो ये आया इसने ट्रू मार्क किया अब ये आगे
जाके मान लो कंडीशन रन करने ही वाला था बट मैं दो प्रोसेस के बीच में तो कॉन्टेक्ट स्विच कर सकता हूं ना हां कर सकते हैं
किसी भी प्रोसेस को कभी भी कॉन्टेक्ट स्विच किया जा सकता है ओस अपना काम कर रहा है सीपी शेड्यूलिंग अपना काम कर रहा है p1
ने रन करना चालू किया उसने भी अपने फ्लैग को देखिए ट्रू मार्क कर दिया और ट्रू मार्क करने के बाद अब जब ये आगे इस वाइल
को चेक करेगा फ्लैग जीरो बताओ फ्लैग जीरो पर क्या मिलेगा सर फ्लैग जीरो ट्रू है तो ये आगे नहीं जा पाएगा p1 यहां पे फंस
जाएगा चार्ज दोबारा p न को दो क्या p न आगे जा पाएगा मेरे को लग रहा है p नो भी आगे नहीं जा पा रहा सर वो भी यहां पर फंस
गया एंड दे यू सी देर इज अ पॉसिबिलिटी ऑफ डेड लॉग डेड लॉग लग गया अभी कोई भी नहीं जा पा रहा यार ये कैसी प्रोग्रेस है दोनों
प्रोसेस जाना चाहते हैं कम से कम एक को तो भेजो टर्न तो ऐसा कर रहा था यह तो किसी को भी नहीं भेज रहा सो दैट इज आल्सो वायलेशन
ऑफ प्रोग्रेस क्यों प्रोग्रेस के अंदर दोनों चीजें थी खैर हम ट्राई कर रहे हैं अब आप बोलेंगे अगेन सर फिर क्यों पढ़ा
सीखने के लिए पढ़ा तो यह सॉल्यूशन भी इनवैलिड है इसमें भी प्रोग्रेस फेल हुआ है लेकिन हां अगर आप ध्यान से सोचेंगे आप
समझेंगे पहले वाले से रिलेटिवली बेटर है अब अगर इन दोनों वेरिएंट्स को मिलाएं तो एक तीसरा सॉल्यूशन पहले पीटरसन सॉल्यूशन
पढ़ाता हूं वो ज्यादा पॉपुलर है ज्यादा इंपॉर्टेंट है एग्जाम पॉइंट ऑफ व्यू से जो टर्न भी यूज़ करता है फ्लैग भी यूज करता
है और शायद ये वैलिड सॉल्यूशन हो कैसे चलिए देखते हैं तो चलिए अभी देखते हैं थर्ड एंड फाइनल अप्रोच जहां पे हम टर्न और
फ्लैग दोनों यूज करेंगे बहुत फैंटास्टिक आईडिया होने वाला है और पीटरसन सॉल्यूशन बहुत कमाल का केस है इसके ऊपर बहुत सारे
क्वेश्चंस आपको मिलेंगे एग्जाम में चलिए एक-एक करके गेम शुरू करते हैं तो आईडिया में पहले से पता है टर्न एक बाइनरी
वेरिएबल होने वाला है जिसका ओरिजिनल वैल्यू जीरो भी हो सकता है वन भी रैंडम हम इसको स्टार्ट करते हैं और फ्लैग हमारे पास
एक एरे है बुलियन एरे दोनों प्रोसेस का एक-एक सेल है और यहां पे हम इन स्टार्ट करते हैं किससे
फॉल्स से तो लेट मी टेक ए आईडिया अगेन परमिट में कि मैं इसको जीरो से चालू करूं शुरू करता हूं मान लेते हैं पी नो ने
शुरू किया टिंग टिंग टिंग टिंग टिंग सबसे पहले पी नो ने बताया कि मेरे को जाना है और जाना है तो हम पता है क्या करना होता
है अपने फ्लैग को ट्रू मार्क करेगा तो पी नोट ने बोल दिया आ एम इंटरेस्टेड आई एम गोइंग इनसाइड द क्रिटिकल सेक्शन बट देखिए
खूबसूरती कितनी मजेदार बात है मैं क्रिटिकल सेक्शन में जाना चाहता हूं बट इस बार ये पूछ नहीं रहा कंपर नहीं कर रहा
असाइन कर रहा है क्या बोल रहा है टर्न इक्वल टूव लेकिन अब हमने वैसे जीरो इनिशिएटिव
लूप है यह सेमीकलन के साथ है इसका मतलब ये एक ट्रैप है और ट्रैप की कंडीशन देखिए बहुत मजेदार कंडीशन है क्या कह रहा है दो
है कंडीशन और बीच में लगा है एंड टर्न इ इव एंड फ्लैग इ इक्व इ टू यानी के मैं यह कंडीशन अगर ट्रू हुई तो मैं यही फसा रह
जाऊंगा मैं लूप में नहीं जाऊंगा तो पी नॉ कह रहा है मैं लूप में नहीं जाऊंगा अगर टर्न मेरे भाई के पास है यानी कि टर्न
इक्व इ 1 है दूसरा फ्लैग ऑफ वन इज आल्सो ट्रू अगर वो जाना चाहता है तो भी अब यहां देखो मजे की बात अभी क्योंकि गेम स्टार्ट
हुआ है तो फ्लैग ऑफ वन में तो फिलहाल फॉल्स है अब अगर एंड में एक कंडीशन भी फॉल्स हो गई तो दूसरा ट्रू फॉल्स कोई फर्क
नहीं पड़ता तो क्योंकि अभी फ्लैग ऑफ वन फॉल्स है कंडीशन फॉल्स पूरा गेम फॉल्स हुआ और लूप अगर फॉल्स है कंडीशन फॉल्स है हम
मा लूप से बाहर और बड़े आराम से पी नो भाई साहब पहुंच गए क्रिटिकल सेक्शन में तो धीरे-धीरे दो-चार बार चलाएंगे ना तो
कंडीशन का फील आना शुरू होता है इतना खूबसूरत तरीके से लिखा है कि अगर वो जाना ही नहीं चाहता दूसरा प्रोसेस तो फिर टर्न
का कोई मतलब नहीं है बिकॉज़ एंड करेंगे तो फॉल्स ही हो जाएगा अगर वो जाना चाहता है तो इस बार डेड लॉक नहीं लगेगा इस बार वो
फाइनल डिसीजन टर्न लेने वाला है कि फिर ये देखा जाएगा टर्न किसका है चलो फिलहाल p नोट बाहर आ गया चलिए ट्राई करते हैं
क्रिटिकल सेक्शन को वायलेट करने की p न चालू करता हूं p न ने कहा मैं भी जाना चाहता हूं तो टर्न की वैल्यू हो गई ट्रू
फ्लैग की वैल्यू और यहां से यह भी अपने भाई ज स ही है इसने बोला मैं जाना चाहता हूं बट टर्न दूंगा अपने भाई को तो उसने
टर्न की वैल्यू देखिए क्या कर दिया जरो एंड नाउ यू कैन लुक एट द कंडीशन क्या टर्न की वैल्यू ज़ीरो है हां है हमने ही करी है
क्या फ्लैग भी ट्रू है हां ट्रू है क्योंकि वो तो क्रिटिकल सेक्शन के अंदर अब दोनों कंडीशन ट्रू है तो बोलो p न जा
पाएगा p1 जा पाएगा कि नहीं नहीं नहीं जा पाएगा यहीं पे बिजी वेट करता रहेगा इजेंट फाइनली आप देखेंगे तो मौका किसको मिलेगा
अगेन p नॉ को जब p नो बाहर आ रहा है क्रिटिकल सेक्शन से तो देखिए फ्लैक को कर रहा है फॉल्स की हां अभी मेरा वन भर गया
और अब जैसे ही ये फॉल्स होगा अगन अगर दोबारा p1 को मौका मिलेगा तो इस बार अगर फ्लैग ही फॉल्स है तो टर्न का कोई लेना
देना नहीं है एंड देन दिस टाइम p1 विल गेट एंट्री इन द क्रिटिकल सेक्शन है ना तो म्यूचुअल एक्सक्लूजन आप जितनी बार चला लो
जैसे चाहे चला लो कुछ भी इसमें वैरायटी नहीं होगी और बहुत आराम से यह क्रिटिकल सेक्शन के अंदर चले जाए जाएंगे पॉइंट नंबर
वन एक बार में एक ही जा पाएगा अब जरा वो वाला सिनेरियो देख लेते हैं जहां प्रोग्रेस का लेशन था अगर p1 इंटरेस्टेड
ही नहीं है और अपने फ्लैग में फॉल्स करके बैठा है मुझे बताओ उस केस में क्या p नॉ मल्टीपल राउंड लगा सकता है क्या हां लगा
सकता है सर कोई प्रॉब्लम नहीं क्योंकि अगर ये कंडीशन ही फॉल्स है तो पूरा वाइल बार-बार फॉल्स होता रहेगा एंड वी कैन हैव
मल्टीपल इटरेशंस इन द लूप तो ये भी काम चलेगा बिल्कुल सही बात है इसमें कोई प्रॉब्लम नहीं है क्या यहां डेड लॉक लग
सकता है इस बार डेड लॉक नहीं लगेगा क्योंकि अगर मैं टर्न वन या यहां टर्न रो करने के बाद कांटेक्ट स्विच कर भी दूं भले
ही आप ऐसा केस बना लो कि दोनों का फ्लैग जो है वो ट्रू हो लेकिन टर्न तो बुलियन है उसकी एक वैल्यू होगी या तो रो या तो वन
जिसके पास होगी वो अंदर जाएगा जिसके पास नहीं होगी वो अंदर नहीं जा पाएगा तो यह आपके लिए प्रॉब्लम क्रिएट नहीं करेगा इस
बार तो फाइनली दो सॉल्यूशन दोनों वैलिड है यानी कि दोनों क्राइटेरिया सेटिस्फाई हुए म्यूचुअल एक्सक्लूजन भी और प्रोग्रेस भी
तो ये जो हमारा पीटर सॉल्यूशन जिसे हम बोलते हैं याद रखिएगा जहां टर्न न फ्लैग और यह तो कोड दो-तीन बार लिख के देखेंगे
समझ लेंगे तो मजा ही आ जाएगा लिख के देख लेंगे तो भी आपको याद हो जाने वाला है तो दिस थिंग विल मेक सेंस और यह 100% बहुत
शानदार तरह से काम करेगा एक इसी का छोटा सा बेसिक वर्जन है जिसे हम बोलते हैं डेकर्स एल्गोरिथम ये भी काफी मिलता जुलता
है एक बार इस अप्रोच को भी आप देख ले वो आपने समझ लिया तो यह भी समझ आएगा कोई भी प्रोसेस है पीआई अब सबसे पहले देखिए उसने
अपने फ्लैग में ट्रू किया पहले की तरह बताने के लिए में जाना चाहता हूं फिर इस बार य एक्चुअल वाइल लूप है इसलिए देखिए
मैंने हिरर की भी यूज़ कि है वाइल फ्लैग ऑफ जे अगर मेरा भाई भी मेरा भाई जो है वह है प्रोसेस पीजे अगर वो भी जाना चाहता है
तो अगर यह फॉल्स हुआ तो देखिए मैं सीधे पहुंच जाऊंगा क्रिटिकल सेक्शन में अगर भाई जाना चाहता है तो मैं जाके चेक करूंगा
क्या टर्न इ इल इ j है अब फिर वही बात जब दोनों के फ्लैक ट्रू है तो गेम किसके पास आएगा टर्न के पास अगर टर्न भी उसका है तो
मैं जाऊंगा और देखिए कितनी खूबसूरती से लिखता है फ्लैग ऑफ आ इ टू फॉल्स कह रहा है कि फिर इसका मतलब मैं इंटरेस्टेड नहीं हूं
और मैं यहां पर तब तक घूमता रहूंगा जब तक जो दूसरा प्रोसेस है उसका टर्न रहता है टर्न इ इक्ट j रहेगा जैसे ही टर्न की
वैल्यू आई होगी ये कंडीशन फॉल्स होगी मैं बाहर आऊंगा और फिर से मैं आके बोलूंगा कि हां अब मैं जाना चाहता हूं फ्लैग ऑफ आ इ
टू ट्रू फिर बाहर आके चेक करूंगा क्या फ्लैग ज फॉल्स हो गया अगर फॉल्स हो गया होगा देन आई विल गो इनसाइड अदर वाइज यही
लूप करता रहूंगा एज सून एज वी एंटर इनटू क्रिटिकल सेक्शन बाहर निकलते हुए देखिए टर्न का वैल्यू क्या किया है j यह बताने
के लिए कि मेरा हो गया है अभी मैं टर्न भी उसको देता हूं तो अपने फ्लैग को भी क्या कर लेता हूं फॉल्स रिमाइंडर सेक्शन है
बाकी डू वाइल ट्रू है जब तक चाहूं जितनी बार चाहूं घूम सकता हूं तो दोनों ही सॉल्यूशन काम करते हैं बट जितना मैंने
देखा है एग्जाम पॉइंट ऑफ व्यू से कॉम्पिटेटिव एग्जाम से पीटरसन इज मोर पॉपुलर अब एक बात
कंक्लूजन भी सॉल्यूशंस हमने काम किए क्या नोटिस करने वाली बात है यह सारे के सारे सारे सॉल्यूशन जो है टू प्रोसेस सॉल्यूशन
है यानी कि एक बार में दो ही प्रोसेस सॉल्व कर सकते हैं दो ही प्रोसेस काम कर सकती है बट इन अ रियल सिनेरियो कंप्यूटर
में कितने प्रोसेस होते हैं वी कैन हैव n नंबर ऑफ प्रोसेस और ए नंबर ऑफ प्रोसेस अगर सॉल्व करना है तो फिर बात करनी पड़ेगी
सीमा फोर्स की तो चलिए डिस्कशन स्टार्ट करते हैं सीमा फोर्स का चलिए नाउ टॉकिंग अबाउट सीमा फोर तो सीमा फोर्स इस प्रॉब्लम
को कैसे सॉल्व करेंगे और क्या अप्रोच होगी बहुत मजेदार आईडिया एक-एक करके नोटिस करिएगा देखिए पहली बात तो समझनी है सीमा
फोर्स कोई डाटा टाइप नहीं है जैसे इंटी जर है फ्लोट है कैरेक्टर है सीमा फोर्स आर आल्सो सिंपल इंटी जर वेरिएबल ये सिंपल
इंटी जर वेरिएबल है बट इसका एक सेपरेट गेम है गेम क्या है अपार्ट फ्रॉम इनिश इइ जशन एक बार आपने इनिश इज कर लिया उसके बाद आप
इसको बार-बार एक्सेस नहीं कर सकते और दो ही ऑपरेशन है जो इसपे अलाउड है फॉर एग्जांपल अगर सीमा 4 की वैल्यू है 10 फॉर
एग्जांपल तो आप ये नहीं बोलोगे कि सर इसको 10 से मल्टीप्लाई कर सकते हैं क्या इसको टू से डिवाइड कर सकते हैं क्या नहीं दो ही
ऑपरेशन अलाउड है एक हम बोलते हैं वेट ऑफ s और एक बोलते हैं सिग्नल ऑफ s वेट का मतलब -1 करना सिग्नल का मतलब + व करना वो भी
कैसे एक्सक्यूज मी वो भी कैसे करना है किस ऑर्डर में करना है एक-एक करके समझते हैं तो सीमा फर आर सिंक्रोनाइजेशन टूल्स व्हिच
आर यूज्ड एंड यूजिंग व्हिच वी विल अटेंप्ट एंड प्रोसेस सॉल्यूशन जैसे मैं बोल रहा हूं दे आर सिंपल इंटी जर वेरिएबल कोई
फैंसी बात नहीं है बट अपार्ट फ्रॉम इनिश इजेशन इट कैन बी एक्सेस ओनली थ्रू टू स्टैंडर्ड एटॉमिक ऑपरेशन जो मैं बोल रहा
हूं वेट एंड सिग्नल और यहां पर एक शब्द देखिए बड़ा इंपॉर्टेंट आया बीच में एटोमिसिटी इसका मतलब जब वेट या सिग्नल कर
रहे तो एटॉमिक मतलब आइर फुल और नन कई बार हमने ये टर्म कंप्यूटर साइंस में ऑब्जर्व करते हैं उसका बीच में कांटेक्ट स्विच
नहीं कर सकते तो यहां पे देखिए काम क्या करता है जब आप सिग्नल कॉल करेंगे फॉर एग्जांपल मान लीजिए मेरा सीमा फर की
वैल्यू रो है कोई कंडीशन नहीं है कोई ड्रामा नहीं है आप जाओगे s+ प् यानी कि + व करोगे बाहर आ जाओगे तो वैल्यू आराम से
हो जाएगी रो से वन कोई फैंसी बात नहीं है जब आप वेट में आओगे यह थोड़ा मेरा को स्मार्ट लगा फॉर एग्जांपल s की वैल्यू वन
है मैं वेट ऑफ s कॉल करूंगा एक कंडीशन है वन फिलहाल वन है ना 1 इज < = 0 क्या वन 0 के बराबर या ज़ीरो से कम है हां जी है तो
अ वन ओ सॉरी नहीं है सॉरी वन इज नॉट लेस दन और इक्वल टू 0 नहीं है कंडीशन फॉल्स आप लूप से बाहर ये भी ट्रैप है आप बाहर s -
माइनस वैल्यू हो गया रो एक बार और ट्राई करूं क्या रो जीरो के कम या बराबर है हां है कंडीशन ट्रू है तो यहीं घूमते रहेंगे
आगे नहीं जाने देगा इसका मतलब वाइल लूप जो है खास करर केस केस में जब हम वेट कर रहे हैं यह आपको ट्रैप कर सकता है कब जब आप
वैल्यू को ज़ीरो से नीचे लेके जाने की कोशिश करेंगे देखिए कहां पे ट्रैप कर रहा है तो यह सॉल्यूशन मजेदार हो सकता है अभी
सॉल्यूशन नहीं है यह तो सिर्फ सीमा फोर की डेफिनेशन है उस टूल की डेफिनेशन जो हम यूज़ करेंगे तो वेट और सिग्नल दोनों
डेफिनेशन आप समझ गए अब मैं आपको डायरेक्टली लेके चलता हूं सॉल्यूशन पे एंड नाउ दिस इज़ अ जेनेरिक सॉल्यूशन फॉर अ
प्रोसेस पीआई सर पीआई मतलब अभी तो हम प्रोसेस p न और p1 की बात कर रहे थे क्योंकि दो प्रोसेस सॉल्यूशन था अभी एन
प्रोसेस सॉल्यूशन की बात कर रहा हूं तो इन जनरल बात कर रहा हूं यस तो देखिए कैसे काम करेगा कोई भी प्रोसेस आया हमने बोला वाइटी
इनिशियल सेक्शन चल रहा है अब देखिए यह पूरा गेम है किसी भी प्रोसेस को जब अंदर जाना है तो अंदर जाने से पहले वेट ऑफ एस
करना है बाहर आना है तो बाहर आते हुए सिग्नल ऑफ एस करना है और यहां पर इस सॉल्यूशन के लिए हम सीमा फर को हमेशा
इनिला इज करेंगे वन से ये बड़ा पोर्टेंट है अगर जीरो से करोगे तो भी गड़बड़ होगा टू से करोगे तो भी गड़बड़ होगा सिर्फ वन
से इनिश इइ करना है ठीक है चलो वन से इनिला करते हैं अब देखते हैं क्या होता है पहली प्रोसेस आई लेट मी से p नॉ p1 ऐसा
करके बहुत सारे प्रोसेस हमारे पास है पहली प्रोसेस आए अब जिसको भी अंदर जाना है क्या अटेंप्ट करना है वेट ऑफ s अटेंप्ट करना है
ट्राई करते हैं अभी क्योंकि फिलहाल s की वैल्यू वन है 1 इज लेसन इक्वल टू 0 कंडीशन फॉल्स है तो माइनस माइनस हो जाएगा तो s की
वैल्यू हुई जीरो और मान लीजिए p नॉ भाई साब क्रिटिकल सेक्शन में यस अब कुछ समय क्रिटिकल सेक्शन में बिताया बहुत हैप्पी
था बट अब कुछ समय के बाद कांटेक्ट स्विच हुआ कंटक्ट स्विच कभी भी हो सकता है अब p1 अटेंप्ट करेगा अब आप मुझे बताइए p1 आया
आया इनिशियल सेक्शन नाउ वेट ऑफ s अटेंप्ट करेगा p1 जरा यहां पे नजर डालिए और मुझे बताइए क्योंकि s की वैल्यू ऑलरेडी रो है
क्या इस बार वेट ऑफ s चलेगा क्या 0 इज लेसन इक्वल टू 0 कंडीशन ट्रू यहीं पे गोल-गोल घूमता रहेगा तो p1 को यू नो
क्रिटिकल सेक्शन में एंट्री नहीं मिलेगी p1 वेट कर रहा है अगर कोई दूसरा प्रोसेस p2 आया वह कर पाएगा कोई भी नहीं कर पाएगा
क्योंकि जो भी करने की कोशिश करेगा s की वैल्यू ऑलरेडी ज़ीरो है नोबडी इज अलाउड टू एंटर इनटू क्रिटिकल सेक्शन नहीं कर पाएगा
क्या करें क्या करें मान लीजिए बहुत सारे प्रोसेस यहीं पे वेट करते रहेंगे कुछ समय के बाद फाइनली पी नॉ भाई साहब का जब मन
भरेगा यह क्रिटिकल सेक्शन से बाहर आएंगे नोटिस करिए बाहर आएगा तो क्या करना है सिग्नल सिग्नल करते हुए कोई कंडीशन नहीं
कोई आईडिया नहीं सीधे + व करो ये वैल्यू हुआ 0 से वन अब मान लो कि p1 जो है अभी वो अपने रिमाइंडर सेक्शन में घूम रहा है अ
सॉरी p न p न भरया ना अब बताओ अगला कौन जाएगा कोई ऑर्डर नहीं है कोई भी जा सकता है तो जिसको भी सीपीयू मिलेगा वो वेट
अटेंड करेगा मान लीजिए p2 p1 के बाद में आया था लेकिन इसको सीपीय मिल गया अब सोचिए जैसे ही ये वेट अटेंप्ट करेगा फिलहाल इस
की वैल्यू क्या है अब आप देख रहे हैं जैसे ही ये वेट अटेंप्ट करेगा फिलहाल इसकी वैल्यू अगेन हो चुकी है वन तो वन में -1
करेंगे वैल्यू हो जाएगा रो जो कि फिलहाल बड़े आराम से हो सकता है और p2 क्रिटिकल सेक्शन में चला जाएगा फिर कोई और अटेंप्ट
करेगा बताओ जा पाएगा क्या बेसिक बात समझ आ रही है n प्रोसेसेस है इनिशिएटिव करना है एक बार में एक ही प्रोसेस जा पा
रहा है मैं जरा सारे आइडियाज याद कर लेता हूं स्टेप नंबर वन अगर सॉल्यूशन वैलिड होना है तो म्यूचुअल एक्सक्लूजन होना
चाहिए आई थिंक यूजिंग दिस सॉल्यूशन कोई भी प्रोसेस रन कर ले मेरे को तो एक बार में में दो प्रोसेस क्रिटिकल सेक्शन में जाते
हुए नजर नहीं आ रही तो म्यूचुअल एक्सक्लूजन तो पक्का होल्ड करेगा इसमें कोई डाउट नहीं है पॉइंट नंबर टू प्रोग्रेस
हमने किसी भी प्रोसेस को जबरदस्ती भेजा क्या नहीं भेजा तो नहीं सर जो एक्चुअली में जाना चाहता है वही जा रहा है अगर कोई
दूसरा प्रोसेस इंटरेस्टेड नहीं है तो एक प्रोसेस मल्टीपल राउंड लगा सकता है हां क्या यहां पर p नॉ p1 को फोर्स कर रहा है
कि बेटा मैं जा चुका हूं अब तुम जाओ फिर p1 प2 को भेजेगा ऐसा कोई राउंड रॉबिन कर रहे हो या स्ट्रिक्ट अल्टरनेशन कर रहे हो
ऐ ऐ भी नहीं हो रहा प्र डेडलॉक भी मेरे को नजर नहीं आ रहा है तो यह फाइनली प्रोग्रेस भी अचीव करता है और अचीव करता है तो इट्स
अ बिग सक्सेस बिकॉज नाउ वी हैव अ सॉल्यूशन व्हिच कैन वर्क ओवर एन प्रोसेस ये टू प्रोसेस सॉल्यूशन है विद द हेल्प ऑफ अ
सीमा फोर्स और ये एन प्रोसेस में सिंक्रोनाइजेशन कर सकता है अब दो मैंडेटरी क्राइटेरिया तो फुलफिल हो गए सॉल्यूशन
वैलिड है बट तीसरा क्या था याद करो तीसरा है हमारा बाउंड वेट लद इफ यू यू नो इसको डिटेल में आप समझोगे तो आपको समझेगा बाउंड
ड वेट नहीं है यहां पे क्यों जैसे मैंने पहले भी बताया ना जब कोई प्रोसेस क्रिटिकल सेक्शन से बाहर आता है अगला कौन सा
प्रोसेस क्रिटिकल सेक्शन में जाएगा यह मौके पर चौका मारने वाली बात है बिकॉज जिसके हाथ में उस समय सीपीयू होगा जो पहले
वेट ऑफ एस को एंप्लॉय कर देगा वो अंदर चला जाएगा तो क्या यहां पर मैं बाउंड वेट गारंटी कर सकता हूं नहीं वो गारंटी नहीं
कर सकता बट मैं याद दिला दूं वो गारंटी करना मैंडेटरी नहीं था डिजायरेबल था बट मैंडेटरी नहीं था तो स्टिल हमारा जो
सॉल्यूशन है यूजिंग सीमा फर वो सॉल्यूशन वैलिड हो जाता है और इन जनरल बाउंड वेट गारंटी करना यानी कि स्टार्वेशन को दूर
करना आमतौर पे वैसे भी बहुत पॉसिबल हो नहीं पाता ज्यादातर केसेस में ऑपरेटिंग सिस्टम में हम वैलिडिटी पे ध्यान देते हैं
बाउंड वेट गारंटी करना मुश्किल होता है तो सीमा फोर का एक बेसिक अंडरस्टैंडिंग आपको क्लियर हो गया अब सीमा फर्स का इस्तेमाल
करके कैसे हम स्टैंडर्ड प्रॉब्लम सॉल्व करते हैं वो देखते हैं और यहां पे बहुत सारी क्लासिकल प्रॉब्लम्स हमारे पास हैं
एग्जाम में पांच पांच 10-10 नंबर में डायरेक्ट क्वेश्चन इनके ऊपर आते हैं जैसे रीडर राइटर प्रॉब्लम है प्रोड्यूसर
कंज्यूमर या बाउंसिंग बाउंड बफर प्रॉब्लम डाइनिंग फिलोसोफर प्रॉब्लम स्लीपिंग बारबर प्रॉब्लम तो सबसे पहले प्रोड्यूसर
कंज्यूमर से शुरू करते हैं तो चलिए अभी बात करते हैं प्रोड्यूसर कंज्यूमर प्रॉब्लम की बहुत मजेदार अप्रोच है किस
तरह से काम करना है क्या-क्या सिंक्रोनाइजेशन करना है एकएक करके आपको समझाता हूं अप्रोच यह है मान के चलिए कि
हमारे पास दो प्रोसेस है अब आप इसे हार्डवेयर के दो मशीनस मान लो दो प्रोसेस मान लो एक प्रोसेस का नाम है प्रोड्यूसर
एक एक प्रोसेस का नाम है कंज्यूमर प्रोड्यूसर एक बार में एक आर्टिकल या एक डाटा सेट कुछ भी मान लेते हैं एक आर्टिकल
बनाता है एक आइटम बनाता है और वो आइटम को कंज्यूम कौन करता है कंज्यूमर बट प्रोड्यूसर डायरेक्टली कंज्यूमर को वो
आइटम नहीं देता यहां पर हमने बीच में एक बनाया हुआ बफर तो प्रोड्यूसर एक आर्टिकल बनाएगा और उसको इस बफर के अंदर रखेगा एंड
बफर के अंदर ए नंबर ऑफ सेल्स है इसलिए कि ऐसा ना हो एक आइटम बनाने के बाद ही प्रोड्यूसर को वेट करना पड़े तो
प्रोड्यूसर ने एक आइटम बना बफर के अंदर रखा अगर कंज्यूमर उस आइटम को फिलहाल कंज्यूम नहीं भी करता तो प्रोड्यूसर को
टेंशन नहीं है वो एक और आइटम बना सकता है एक और आइटम बना सकता है कब तक जब तक बफर पूरा फिल ना हो जाए तो प्रोड्यूसर के
फ्रेम ऑफ रेफरेंस में देखेंगे दो-तीन बात का ध्यान रखना है प्रोड्यूसर का डायरेक्ट कंज्यूमर से कोई लेना देना नहीं है
प्रोड्यूसर का लेना देना है बफर से उसको जब भी आर्टिकल प्रोड्यूस करेगा इस बफर के अंदर ऐड करता जाएगा बस किस बात का ध्यान
रखना है ओवरफ्लो ना हो यर किसी आइटम को प्रोड्यूस करके बफर को अटेंप्ट तब करें एक्सेस करने का जब वहां पर कम से कम एक
सेल खाली हो ताकि वह आइटम रख सके टॉकिंग अबाउट कंज्यूमर कंज्यूमर भी उसी तरह इंडिपेंडेंट है उसका प्रोड्यूसर से
डायरेक्ट कोई लेना देना नहीं है अगर प्रोड्यूसर कुछ समय के लिए काम नहीं कर रहा तो भी अगर सेल्स के अंदर मल्टीपल
वैल्यूज हैं तो कंज्यूमर एक-एक करके उनको कंज्यूम कर सकता है कंज्यूमर को किस बात का ध्यान रखना है एक बार में एक एलिमेंट
ही कंज्यूम करेगा दूसरा ये जो पूरा हमारा बफर है अंडरफ्लो ना हो इस बफ बर को जाके मैं एक्सेस तब करूं जब कम से कम एक सेल
भरा हुआ हो इन जनरल बफर प किस बात का ध्यान रखना है एक ही टाइम पे दोनों एक्सेस ना कर ले क्योंकि प्रोड्यूसर कंज्यूमर अगर
दोनों एक साथ एक्सेस करेंगे तो भी क्लैश होगा तो प्रोड्यूसर ओवरफ्लो का ध्यान रखेगा कंज्यूमर अंडरफ्लो का ध्यान रखेगा
और हम दोनों इन मिलके इस बात का ध्यान रखेंगे कि यह सब के सब एक साथ एक्सेस ना कर ले यह एक शॉर्ट में डिस्क्रिप्शन है
प्रोड्यूसर कंज्यूमर प्रॉब्लम का बाकी सारी डिटेल्स वन बाय वन मैंने मेंशन की है हम यहां पर यूज क्या करेंगे हम तीन सीमा
फोर यूज करेंगे एक सीमा फोर यूज करेंगे s जिसको इनिश इज करेंगे वन से व्हिच इज लाइक अ क्रिटिकल सॉल्यूशन जो मतलब इस बात का
ध्यान रखिएगा एक टाइम पर प्रोड्यूसर कंज्यूमर एक साथ क्लैश ना करें तो ए की ड्यूटी मैंने आपको बता दी वो क्रिटिकल
सेक्शन का ध्यान रखिएगा कोऑर्डिनेशन का दो और सीमा फोर है e और f e मतलब एमटी सेल्स जब गेम शुरू होगा तो बताओ सारे के सारे
सेल तो खाली होंगे n के एन सेल्स इसलिए मैं e को इनिश इज कर रहा हूं n से और ये एक एग्जांपल है काउंटिंग सीमा फोर्स का
क्योंकि सिर्फ रो व दो वैल्यू में हम डील नहीं कर रहे सिमिलरली ए बताएगा फील्ड कितने हैं और उसको इलाइट कर रहा हूं ज
जीरो से क्योंकि जब गेम स्टार्ट होगा तो सारे के सारे सेल हमारे खाली होंगे तो फिल वाला तो जीरो होगा एमटी वाला n होगा ये
तीनों बातें आपको समझ आ गई अब कोड पे आ जाते हैं एक तरफ प्रोड्यूसर एक तरफ कंज्यूमर है एक-एक करके आपका टाइम भी बचवा
ंगा लेकिन पैटर्न याद तो आप करोगे बट टना ना पड़े आपको बात समझ आए तभी एग्जाम में अच्छे से लिख पाओगे तो क्या करना है एकएक
करके फिल करता हूं पहले मुझे बात बताओ प्रोड्यूसर की प्रोसेस का नाम प्रोड्यूसर कंज्यूमर की प्रोसेस का नाम कंज्यूमर वाइल
टी वाइल ट्रू ये तो एक स्टैंडर्ड पैटर्न है जो हर बार अब हम फॉलो कर रहे हैं आपके लिए कोई नई बात नहीं है आगे बढ़ता हूं दो
तीन जो यू नो कमेंट स्टेटमेंट है जब गेम शुरू होता है तो प्रोड्यूसर एक आइटम प्रोड्यूस करेगा जिसका कंज्यूमर से कोई
लेना देना नहीं है सिमिलरली कंज्यूमर पूरी प्रोसेस करने के बाद आइटम कंज्यूम करता है अगर प्रोड्यूसर बफर एक्सेस कर पाएगा तो
बीच में कहीं जाके वह बफर में अपने आइटम को ऐड कर देगा और कंज्यूमर अगर एक्सेस कर पाएगा तो बीच में कहीं पे जाके वो बफर्स
उस आइटम को पिक करेगा तो धीरे-धीरे मैं स्ट्रक्चर भरते चलूंगा ताकि एक साथ भरू तो आपको ना लगे क्या हो गया नाउ गोइंग टू द
नेक्स्ट स्टेप क्योंकि हमें पता है कि बफर एक शेयर्ड यू नो सेक्शन है क्रिटिकल सेक्शन है शेयर्ड रिसोर्स है एक बार में
दोनों अटेंप्ट नहीं कर सकते हम पहले से घर से क्या सीख के आए हैं कि जो भी शेयर्ड रिसोर्स होगा वो क्रिटिकल सेक्शन है वहां
सिक्योरिटी होना चाहिए तो मुझे बताओ यह दोनों बातें लिख के मैंने कोई नई बात की है क्या वैसे ही इसका काम है सिक्योरिटी
देना तो जो भी अंदर जाएगा अंदर जाने से पहले वेट करेगा बाहर आते हुए सिग्नल करेगा चाहे फिर वो प्रोड्यूसर हो वो कंज्यूमर हो
मान लीजिए प्रोड्यूस अंदर अंदर जाता है वेट ऑफ एस करता है ये तो वैल्यू हो गई जीरो अब आप मुझे बताओ अगर इस समय कांटेक्ट
स्विच हो गया प्रोड्यूसर अटेंप्ट करेगा अंदर जा पाएगा क्या नहीं जा पाएगा क्योंकि वेट की वैल्यू बताइए क्या है s की वैल्यू
फिलहाल जीरो है इजेंट इट तो अंदर नहीं जा पाएगा यहीं पे वेट करना पड़ेगा फाइनली जब यह बाहर आएगा सिग्नल करेगा वैल्यू वन तब
कंज्यूमर अंदर जा पाएगा तो s बहुत आराम से दोनों का कोऑर्डिनेशन मैनेज कर रहा है अब बात आई ओवरफ्लो और अंडरफ्लो की अगले स्टेप
में इस कहानी को सॉल्व करता हूं तो देखो एक बात समझना प्रोड्यूसर जब कोई एलिमेंट प्रोड्यूस करेगा तो एक बात तो तय है क्या
प्रोड्यूसर जब एलिमेंट प्रोड्यूस करेगा तो जो एमटी सेल्स हैं वो एक कम होंगे और जो फुल सेल्स हैं जो फील्ड है वो एक बढ़ेंगे
मतलब जो हमारा एमटी वाला सेल है वो होगा e स्टैंड्स फॉर एमटी एमटी -1 और जो फील्ड वाला सेल है वो होगा फीड + 1 मानते हो
यहां पर -1 मतलब वेट ऑपरेशन + 1 मतलब सिग्नल ऑपरेशन तो ये तो तय था कि प्रोड्यूसर को दो काम करने हैं उसको e के
ऊपर वेट करना ए के ऊपर सिग्नल करना बट कौन सा पहले करना वो मैं बता रहा हूं अंदर जाते हुए पहले वेट करना है e पे और बाहर
आते हुए यह ये गलत लिख दिया इसको लिखना है सिग्नल बाहर आते हुए सिग्नल करेगा f पे अब
क्योंकि हमने बात समझी तो रटने की कोई बात ही नहीं है सिमिलरली इधर आ जाइए यहां पर भी गड़बड़ लिखा है यस अंदर जाते हुए उल्टा
करेगा ये अंदर जाते हुए वेट करेगा f के ऊपर क्यों क्योंकि कंज्यूम वारा कंज्यूम करेगा तो फील्ड वाले कम होंगे और यहां लिख
दीजिए सिग्नल ये सिग्नल करेगा e के ऊपर सिग्नल वाली यानी कि एमटी वाले बढ़ जाएंगे क्योंकि एलिमेंट कंज्यूम कर रहा है मैं हर
बार पहले वेट क्यों करना चाहता हूं देखिए वेट ही वो ऑपरेशन है जहां पर किसी प्रोसेस को रोका जा सकता है अब इमेजिन करिए
प्रोड्यूसर अगर प्रोड्यूस कर रहा है और दो मिनट के लिए इमेजिन करें कि सारा बफर भरा हुआ है तो इस केस में एमटी वाले क्या
होंगे इस केस में एमटी वाले जीरो होंगे और फिल वाले हो जाएंगे n अब आप मुझे बताइए यह जीरो पे वेट कर पाएगा क्या पहले से आपको
स्टोरी पता जीरो पे वेट कर ही नहीं पाएगा यही गोल-गोल घूमता रहेगा सिमिलरली अगर कंज्यूमर कंज्यूम करे और एमटी वाले सारे
हो और फिल वाला जीरो हो मुझे बताओ f के ऊपर वेट कर पाएगा क्या नहीं कर पाएगा तो ये दो चेंज तो आप कर लेंगे वेट और सिग्नल
वाली बात और यह पूरा पैटर्न अब मेरे ख्याल से आपको समझ आ गया प्रोड्यूसर कंज्यूमर क्या प्रॉब्लम है तीन ओवरफ्लो अंडरफ्लो और
आपस का सिंक्रोनाइजेशन तीनों प्रॉब्लम्स को हमने अच्छे से टैकल कर लिया यह भी समझ लिया प्रोड्यूसर कौन से दो काम करता है
कंज्यूमर कौ से दो काम करता है और क्यों पहले वेट कर र है बाहर सिग्नल कर रहे है क्योंकि वेट पर रोका जा सकता है सिग्नल पर
नहीं रोका जा सकता यस सो दैट इज इतना लिख के आओगे तो कहानी आपकी कंप्लीट हो गई गोइंग टू द नेक्स्ट प्रॉब्लम नाउ वी हैव
रीडर राइटर प्रॉब्लम अब जैसे प्रोड्यूसर कंज्यूमर है ऐसे ही यहां पर रीडर राइटर है तो प्रॉब्लम समझिए पहले हमारे पास एक
शेयर्ड पीस ऑफ टेक्स्ट है है ना कोई शेयर्ड डाटा है इसके ऊपर दो तरह के प्रोसेस काम करते हैं कुछ प्रोसेस राइटर
प्रोसेस है कुछ रीडर अच्छा यहां पे एक बात समझिए प्रोड्यूसर कंज्यूमर में हम मान रहे थे एक ही प्रोड्यूसर है एक ही कंज्यूमर है
यहां पे देयर कैन बी मल्टीपल राइटर्स एंड देयर कैन बी मल्टीपल रीडर्स नाउ एक बात जो बड़ी कॉमन सेंस की है क्या एक बार में
बहुत सारे रीडर रीड ऑपरेशन परफॉर्म कर सकते हैं आई थिंक कर सकते हैं रीडर रीडर का आपस में क्लैश नहीं होता डेटाबेस में
इस बात को बहुत अच्छे से समझते हैं हम तो रीडर रीडर का कोई इशू नहीं है बट क्या एक बार में मल्टीपल राइडर काम कर सकते हैं
नहीं तो तो राइटर का राइटर के साथ भी क्लैश है राइटर राइटर दे इज अ प्रॉब्लम एंड राइटर रीडर देर इज अ प्रॉब्लम तो अब
सोचिए मैं किस तरह का मैकेनिज्म बनाना है शेयर्ड पीस ऑफ टेक्स्ट है अगर राइटर अंदर है राइटर प्रोसेस काम कर रही है कोई राइट
ऑपरेशन परफॉर्म कर रहा है तो उस समय ना तो रीडर अंदर आए ना तो राइटर अंदर आए वो बड़ा स्ट्रिक्ट है लेकिन अगर रीडर अंदर है तो
वी कैन बी लिटल बिट फ्लेक्सिबल उस केस में रीडर अंदर आ सकता है क्योंकि रीडर रीडर दो लोग पढ़ेंगे तो उसका कोई क्लैश नहीं होगा
बट राइटर उस केस में अंदर नहीं आ सकता है ना इतनी बात हमें समझ आती है अब इसके लिए
अगेन हमें सॉल्यूशन लिखना है सॉल्यूशन के लिए सारी पॉइंट मैंने आपको बता दिए क्या-क्या यूज करेंगे एक हम सीमा फोर यूज
करेंगे म्यूट्स म्यूट्स अगेन म्यूचुअल एक्सक्लूजन जिस बात का ध्यान रखिएगा एक टाइम में दो लोग अंदर ना आ जाए और टेक्स
का भी इस्तेमाल आपको बताऊंगा यह वैसे दो रीडर के बीच में दो रीडर को आपस में यू नो को रिलेट करने की कोशिश करेगा राइटर एक और
होगा जो राइटर टू राइटर या राइटर टू रीडर काम करेगा और एक सिंपल इंटी जर वेरिएबल है रीड काउंट ये सीमा फोर नहीं है ये इस बात
को याद करने में मेरे को हेल्प करेगा कि फिलहाल क्रिटिकल सेक्शन में कितने रीडर्स हैं एज मल्टीपल रीडर्स कैन बी देयर तो ये
इस्तेमाल कैसे होंगे किस तरह से होंगे मैं एक-एक करके आपको समझाता हूं तो वही अप्रोच यूज़ कर लेते हैं इन द स्टार्टिंग दो
प्रोसेसर रीडर राइटर जब राइटर क्रिटिकल सेक्शन के अंदर होगा है ना तो वहां पे राइट ऑपरेशन परफॉर्म करेगा और जब रीडर
अंदर होगा तो रीड करेगा गेस करोगे एक मिनट सोच के किसका कोड आसान होगा रीडर का कि राइटर का कई लोग सोचते हैं शायर रीडर का
आसान होगा बट कहानी उल्टी है राइटर का कोड बहुत आसान है उसको टेंशन नहीं है अगर गेट पर नॉक हुआ उसको टेंशन है क्या बाहर रीडर
है कि राइटर है कोई भी है मेरा दुश्मन है क्योंकि राइटर का तो दोनों के साथ क्लैश है तो उसे गेट ओपन नहीं करना है तो यहां
पर ऑब्जर्व करिए इधर लिख र है वेट इधर लिखना सिग्नल तो राइट को हम इनिशिएटिव से अंदर जो भी जाएगा पहले क्या करेगा पहले
राइट को फॉर एग्जांपल वन से कर देगा जीरो फिर क्या कोई दूसरा राइटर अंदर आ पाएगा जी नहीं आ पाएगा जैसे ही ये बाहर आएगा दोबारा
जीरो से इसको कर देगा वन सो दैट इज हाउ ये राइटर यहां पे परफेक्ट तरह से काम करेगा अब मैं रीडर पे बा काम करता हूं रीडर को
धीरे-धीरे आगे लेके चलता है देखिए रीड काउंट क्या है एक सिंपल इंटी जर वेरिएबल है जो काउंट रखता है कितने रीडर मेरे पास
है जब कोई प्रोसेस रीडर अंदर जाएगा तो रीड काउंट प्लस होगा बाहर आएगा रीड काउंट माइनस होगा बहुत कॉमन सेंस बात है
धीरे-धीरे एड ऑन करते चलूंगा कोई कंफ्यूजन नहीं होगा हां सर इतनी बात तो समझ आती है फेयर इनफ अब आप मुझे बताओ ये जो रीड काउंट
है ध्यान से देखना यह रीड काउंट तो शेयर्ड वेरिएबल है ना हां शेयर्ड है बिटवीन द रीडर्स क्योंकि अगर एक से ज्यादा रीडर एक
साथ प्लस प्लस करने की कोशिश करेंगे पहले वाला कोड है याद है इंक्रीमेंट वाला जहां से प्रॉब्लम पढ़ना शुरू किया था हमने
सिंक्रोनाइजेशन प्रॉब्लम हो सकता है तो क्या रीड काउंट को भी सिक्योरिटी चाहिए सिक्योरिटी चाहिए और यहां देखिए पेयर में
सिक्योरिटी आपको नजर आ रही है तो जैसे मैंने बोला था टेक्स जो है उसका राइटर से कोई लेना देना नहीं है मूटे सिंक्रोनाइज
करने में मदद करता है बिटवीन टू रीडर्स ताकि दो रीडर एक बार में रीड काउंट को खराब ना कर दें तो अगर कोई रीडर अंदर आता
है तो पहले टेक्स को वेट करेगा ऑब् वियस टेक्स इज इनिला विद वन रीड काउंट प्लस करेगा एंड देन बिफोर एंटरिंग इन टू
क्रिटिकल सेक्शन दोबारा से सिग्नल कर देगा ताकि बाद और रीडर भी अंदर आ सके सिमिलरली बाहर निकलते हुए रीड काउंट को माइनस करना
चाहिए क्योंकि अब रीडर कम होंगे लेकिन अगेन ब क्रिटिकल सेक्शन है शेयर्ड वेरिएबल है डायरेक्ट टच नहीं करूंगा पहले टेक्स को
वन से जीरो करूंगा फिर रीड काउंट माइनस करूंगा बाहर जाते हुए मैं दोबारा इसको वन कर दूंगा कि बाकी रीडर काम कर सके तो
टेक्स और इसकी सिक्योरिटी रीड काउंट यह पूरा मैकेनिज्म है किस लिए सिर्फ रीडर्स में आद में सिंक्रोनाइज करने के लिए नाउ
गोइंग इन टू द नेक्स्ट स्टेप यह जो राइट ऑपरेशन पर वेट ऑपरेशन करना ये सबको नहीं करना समझाता हूं कैसे और कैसे यहां पर
कंडीशन काम करेगी देखिए एक केस देखिएगा टेक्स इनिला इज विद वन राइट इनिला विद वन रीडर इलाज विद रो पहला रीडर अंदर आता है
जैसे ही आएगा सबसे पहले यह पेयर आपको पता है क्यों हमने लगाया लुक एट दिस पेयर तो टेक्स को इसने किया जीरो रीड काउंट को
इसने किया वन और अब ये चेक कर रहा है इफ रीड काउंट इ इ इक्व हां वो तो वन ही है अगर प्लव करने के बाद भी रीड काउंट वन है
इसका मतलब शायद मैं पहला रीडर हूं और अगर मैं पहला रीडर हूं तो क्या कोई और राइट पे वेट ऑपरेशन परफॉर्म किसी ने किया होगा
नहीं किया होगा मुझे करना है ताकि जब मैं अंदर जाऊं तो रीडर तो अंदर आ सके बट राइटर अंदर ना आए तो अब मैं यहां पर इसको जरो कर
राइटर को सिर्फ यही समझ आता है यस तो मैंने इसको जरो किया बट अंदर जाने से पहले टेक्स को वन कर दूं ताकि राइटर नहीं बट
दूसरे रीडर अंदर आ सके अब सोचिए जब अगला रीडर अंदर आएगा वो फिर टेक्स को मेंटली रो करेगा रीड काउंट को टू करेगा और इस बार
कंडीशन चेक करेगा इफ रीड काउंट इज इक्व इ इक्व टू 1 नहीं रीड काउंट तो टू है टू इज नॉट इक्वल टू 1 कंडीशन फॉल्स वो सीधे आगे
आएगा टेक्स को रो जो हो चुका है उसे दोबारा वन करेगा एंड गो इनसाइड द क्रिटिकल सेक्शन कितना खूबसूरत लिखा हुआ है
सिमिलरली सोचिए जब आखिरी रीडर बाहर आएगा रीड काउंट की वैल्यू हो जाएगी जीरो तो उसको बाहर आने से पहले वेट पे सिग्नल कर
देना चाहिए अदर वाइज इट विल लीड टू डेडलॉक फिर तो कोई आ ही नहीं पाएगा लेकिन अगर बीच में किसी रीडर ने गलती से सिग्नल कर दिया
तो राइटर अंदर आ जाएंगे और गड़बड़ हो जाएगी मेरे ख्याल से पूरा मैकेनिज्म रीडर और राइटर का बहुत खूबसूरत है और बहुत कम
समय में और अच्छे से मैंने समझाने की कोशिश की है फिर वही बात यह पूरा सॉल्यूशन लिखेंगे तो कोई नंबर आपके कटने वाले नहीं
है 10 में से लेट्स सी कितने मिलते हैं कितने यह पूरा टेबल बनाना है पूरा मैकेनिज्म सारी रिसोर्स समझाओ कि टेक्स का
क्या इस्तेमाल है रीड काउंट का क्या इस्तेमाल है वेट का क्या इस्तेमाल है एंड प्रॉब्लम का डेफिनेशन क्या था तो यू आर
गोइंग टू गेट द मार्क्स यस प्रोसीडिंग फॉरवर्ड अगला नंबर आ जाता है डाइनिंग फिलोसोफर का तो यह बड़ी शानदार प्रॉब्लम
है थोड़ी मजाकिया प्रॉब्लम है समझिए एक बार क्या लॉजिक है व्हाट डू वी हैव जैसा आप इस इमेज में देख पा रहे हैं एक सर्कुलर
टेबल हमारे पास है स्टैंडर्ड प्रॉब्लम में डेफिनेशन बुक बाय बुक थोड़ा बहुत इधर-उधर हो सकता है बट द फंडामेंटल आइडिया रिमेंस
द सेम सो दिस इ सर्कुलर टेबल मेरे जो एग्जांपल मैंने लिया इसमें फाइव फिलोसोफर है सेवन हो स नाइन हो सकते है बेसिकली वी
टेक ऑड नंबर ऑफ फिलोसोफर तो हमारे पास कुछ फिलोसोफर बैठे हुए हैं अब ये दो ही काम करते हैं या तो यह खाते हैं आइर दे ईट और
दे थिंक बस दो ही काम करते हैं या तो खाते हैं या तो सोते हैं या तो सोचते हैं यस अब जब भी इनको भूख लगती है तो व्हाट वी से कि
सपोज देर इज अ बाउल ऑफ राइस और यू नो नूडल्स इन बिटवीन द टेबल और इनको खाने के लिए दो फॉक या दो चॉपस्टिक चाहिए है ना हर
किसी के पास अपने इंडिपेंडेंट चॉप स्टिक्स नहीं है सो व्हाट दे हैव इज लाक एवरी बडी हर दो फिलोसोफर के बीच में एकएक चॉपस्टिक
है तो इफ आई नंबर देम दिस इज लाइक फिलोसोफर नंबर रो नंबर वन नंबर टू नंबर थ्री नंबर फोर चॉपस्टिक नंबर जीरो नंबर वन
नंबर टू नंबर थ्री नंबर फोर तो अगर पांच फिलोसोफर है तो पांच ही चॉपस्टिक है अगर फिलोसोफर नंबर टू को खाना है तो उसको
चॉपस्टिक नंबर टू और चॉपस्टिक नंबर थ्री या फॉक नंबर टू फॉक नंबर थ्री पिक करना है खाना एंड देन काम करना है अब अगेन हमें एक
सॉल्यूशन लिखना है विद द हेल्प ऑफ द सीमा फोर्स कि हम इसको सिंक्रोनाइज करें इस पूरी प्रोसेस को ताकि इसमें प्रॉब्लम ना
हो अगर आप इसे एनालाइज करना शुरू करेंगे मैंने पूरा प्रॉब्लम का डेफिनेशन आपको बता दिया सब यहां पे लिखा है अगर आप इसे
एनालाइज करना शुरू करेंगे तो कुछ समय के बाद आपको समझ आएगा कि जो बाउल ऑफ राइस है ना दैट इज नॉट क्रिटिकल सेक्शन क्या एक
बार में दो लोग खा सकते हैं फॉर एग्जांपल अगर एडजेसेंट नहीं है लाइक दिस थ्री नंबर एंड जीरो नंबर फिलोसोफर कैन ट एट द सेम
टाइम वन नंबर फोर नंबर वन नंबर थ्री नंबर आई थिंक किसी भी टाइम पे तीन तो नहीं बट दो फिलोसोफर बड़े आराम से खा सकते हैं तो
ये तो क्रिटिकल सेक्शन नहीं है क्रिटिकल सेक्शन कौन है क्रिटिकल सेक्शन है ये चॉपस्टिक या ये फॉक्स पांच है पांच
क्रिटिकल सेक्शन यहां पे है क्यों एक बार में क्या चार नंबर और तीन नंबर दोनों खाना खा सकते हैं नहीं हमें इस बात का ध्यान
रखना है क्योंकि जो चॉपस्टिक है ये शेयर्ड है क्या एक बार में वन नंबर और टू नंबर खा सकते हैं नहीं क्योंकि हमें इस बात का
ध्यान रखना है कि ये जो चॉपस्टिक नंबर टू है ये शेयर्ड है है ना इसके बीच में सिंक्रोनाइज करना है अब लोग सिंक्रोनाइज
कराते कैसे हैं ये मैंने पता नहीं क्यों इमज मैंने बीच में लगा दिया भाई बहुत संकोच में है पता नहीं खा
पा रहा है नहीं खा पा रहा है फिर मुझे इंडियन चॉप स्टिक भी याद है ये सब ड्रामा है क्या जरूरत है जब आराम से खाना खा सकते
हैं यस चलो जोक्स अ पाड नाउ लेट मी गो टू द आईडिया कैसे इसको सॉल्व करते हैं सोल्यूशन देखिए आपको समझाता हूं तो यहां
पर हम क्या करते हैं हम एक एरे लेते हैं ऑफ सीमा फोर्स मजेदार बात है तो यहां पे लेट मी से इन्होंने कैसे लिया वेट एंड ट
चलो मैं वन से इनिश इइ करता हूं देर इज अ सीमा फोर सीमा फोर का नाम मैं रख देता हूं चॉपस्टिक शॉर्ट में लिख देता हूं इंडेक्स
नंबर 0 1 2 3 4 तो ये सारे के सारे नंबर अलग-अलग चॉपस्टिक को रिप्रेजेंट करते हैं अगर चॉपस्टिक नंबर टू फिलहाल वन है इसका
मतलब चॉपस्टिक नंबर टू जो है वो अभी अवेलेबल है लाइक दिस नंबरिंग कर देता हूं दोबारा
से वो भी अवेलेबल है अब मान लीजिए इट इज वैलिड फॉर एनी फिलोसोफर लेट मी से फिलोसोफर नंबर टू ले लेते हैं फिलोसोफर
नंबर टू अभी तक थिंकिंग कर रहा था उसको खाने का मन किया क्या करना उसको उसको इंडेक्स नंबर टू और 2 + 1 3 टू और थ दोनों
पे वेट ऑपरेशन परफॉर्म करना अब नोटिस करिए जैसे ही ये वेट ऑपरेशन करेगा क्या होगा लॉजिकली फिलोसोफर नंबर टू था ना चॉपस्टिक
नंबर टू मान सकते चॉपस्टिक नंबर थ्री एक तरह से इसके पास आ गई और अब यह बहुत आराम से ईट करेगा बाहर निकलते हुए फिर दोनों को
रिलीज कर रहा है दोनों पे सिग्नल कर रहा है तो अगेन बोथ ऑफ देम आर गोइंग टू बिकम वन ये ये वाला क्या कहानी मैंने लिखी
क्योंकि इंडेक्स है ना राउंडेड है अगर फिलोसोफर नंबर फोर खाएगा तो क्या होगा चॉपस्टिक नंबर फोर दिस विल बी 0 एंड 4 + 1
5 5 डिवाइड बा 5 रिमाइंडर रो तो ये दोबारा घूम के आ जाएगा ये तो जब फोर को खाना तो फोर और जीरो नंबर चॉपस्टिक के थ्रू वो खा
सकता है वैसे पहली बार में देखते हैं तो सॉल्यूशन परफेक्ट लगता है हर किसी को यही काम करना है अपने दोनों चॉपस्टिक उठाने
हैं खाना है फिर दोनों रिलीज कर देने हैं बट इसमें एक प्रॉब्लम है दिस सॉल्यूशन सफर्स फ्रॉम डेड लॉक तो बेसिकली ये
प्रोग्रेस को वायलेट कर देता है कैसे एक सिचुएशन है फिलोसोफर नंबर जीरो ने खाना खाना चालू किया और जैसे ही वो खाना खाने
के बारे में सोचेगा तो पहले चॉपस्टिक नंबर रो उठाता है वन उठाता है उसके बाद अगर उसने चॉपस्टिक नंबर जीरो उठाई और मैंने
उसे वहीं पर कांटेक्ट स्विच कर दिया क्या मैं कर सकता हूं सर फिर वही बात किसी भी प्रोसेस को कभी भी कांटेक्ट स्विच किया जा
सकता है हां कर सकता हूं फिर बोलो अगला नंबर किसका आएगा अगला नंबर आएगा फिलोसोफर नंबर वन का अब वोह क्या करेगा अपने कोड के
हिसाब से वह पहले वन नंबर उठाएगा मान लीजिए उसने वन नंबर उठाया मैंने फिर से उसको कांटेक्ट स्विच कर दिया एंड फॉलोइंग
द सेम आइडिया देयर कुड बी अ सिनेरियो कि एक-एक चॉपस्टिक सारे फिलोसोफर पिक कर लेंगे और यह एक स्टैंडर्ड केस है डेड लॉक
का यहां डेड लॉक लग जाएगा अब कोई भी खा नहीं पाएगा एक-एक चॉपस्टिक सबके पास एंड द सिस्टम सफर्स फ्रॉम डेड लॉक तो यह एक
स्टैंडर्ड सॉल्यूशन है जहां पर हम समझते हैं कि यह सॉल्यूशन वैलिड नहीं है इसको वैलिड बनाने के बहुत सारे अलग-अलग सजेशंस
है जैसे क्या-क्या सजेशंस हो सकते हैं सजेशंस इसको सॉल्व करने के तो पहला सजेशन है कि एक बार में सिर्फ चार फिलोस
फर्स को ही टेबल पर अलाव करो सोचो अगर चार फिलोसोफर होंगे तो हर कोई एकएक उठाएगा फिर भी एक चॉपस्टिक बचेगा वो किसी ना किसी को
मिलेगी जिसको मिलेगी वो रन करेगा रन करेगा रिलीज करेगा डेडलॉक नहीं लगेगा एक दूसरा सॉल्यूशन क्या हो सकता है अलाउ सिक्स
चॉपस्टिक पांच तो है एक एक्स्ट्रा रख दो तो या तो फिलोसोफर एक कम करो या तो चॉपस्टिक एक बढ़ा दो अभी चॉपस्टिक एक
बढ़ाओ ग तो एडिशनल चॉपस्टिक किसी ना किसी को मिलेगी जिसको मिलेगी उसको खाना है रन करना है एग्जीक्यूट करना है अगेन डेड लॉक
नहीं लगेगा बट ये जो दोनों सॉल्यूशन है कि या तो आप एक चॉपस्टिक कम करो या तो फिलोसोफर या तो चॉपस्टिक एक बढ़ा दो या
फिलोसोफर एक कम करो ये थोड़ा सा प्रॉब्लम की डेफिनेशन को चेंज कर रहे हैं तो अगर प्रॉब्लम की डेफिनेशन को चेंज नहीं किया
जाए तो क्या किया जा सकता है अलाव फिलोसोफर टू पिक हर चॉप्स ओनली बोथ द चॉपस्टिक आर अवेलेबल है ना तो एक गेम हो
सकता है कि अगर एक चॉपस्टिक है और दूसरी नहीं है तो पहला भी आप रिलीज करा दो तो रिलीज करा दोगे तो भी डेड लॉक नहीं लगेगा
एक लॉजिक क्या हो सकता है कि यू नो प्रॉब्लम हो रही है कि हर कोई अलग-अलग चॉपस्टिक उठा रहा कोड सबका सेम है बट वो
हर किसी का सिनेरियो अलग है तो हम कुछ ऐसा कर सकते हैं लेट मी से n -1 फिलोस फर जो है वो हर कोई अपनी राइट चॉपस्टिक पहले
उठाएगा एवरीबॉडी विल पिक द राइट चॉपस्टिक फर्स्ट लेकिन जो एंथ फिलोसोफर है वो अपनी लेफ्ट चॉपस्टिक पहले उठाएगा तो देखो इससे
होगा क्या इमेजिन करो आप तो मैं डिवाइड कर रहा हूं n n - व में और वन में तो मान लीजिए ये जो जीरो नंबर है ये पहले अपनी
राइट उठा रहा है ये भी पहले राइट पिक करेगा ये भी पहले राइट पिक करेगा ये भी पहले राइट पिक करेगा बट ये जो फिलॉसफी है
ये अपनी लेफ्ट चॉपस्टिक पहले पिक करेगा तो यानी कि ये जो हमारे पास चॉपस्टिक है ना अब इस पे हुआ क्लैश या तो ये जीरो नंबर
वाले फिलॉसफी या तो फोर वाले को लेकिन किसी एक को को मिलेगी मान लेते हैं कि जीरो वाले फिलोसोफर को मिल गई अब फोर वाले
के साथ प्रॉब्लम क्या है हमने उसको ट्रेन कर दिया कि यार पहले तू लेफ्ट उठा फिर तू राइट उठा सकता है अब जब उसको लेफ्ट
चॉपस्टिक नहीं मिलेगी तो अब क्या वो राइट चॉपस्टिक पिक कर सकता है नहीं कर सकता बेसिकली वो इस कंपटीशन से बाहर हो जाएगा
और ये जो बची हुई चॉपस्टिक है किसी ना किसी को मिलेगी ओबवियसली ये ग्रीन वाले को मिलेगी और जिसको मिलेगी डेड लॉक रिजॉल्व
होगा है ना तो कुछ लोग यहां पे दो तरह से काम करते हैं एक तो हुआ टोटल n है n - 1 एक तरफ रखे वन एक तरफ रखे एक और दूसरा
अप्रोच क्या हो सकता है कि n हमारे पास है ऑड और इवन में डिवाइड कर ले लेट द ऑड नंबर फिलोसोफर पिक द लेफ्ट चॉपस्टिक फर्स्ट और
द इवन नंबर विल पिक द अदर वे राउंड लाइक लाइक द ऑड चॉपस्टिक फर्स्ट तो अगर सब को ई सेम ऑर्डर फॉलो ना करके डिफरेंट ऑर्डर
फॉलो करेंगे तो भी हमारा क्लैश रिजॉल्व हो जाएगा तो यह आमतौर पे सबसे पॉपुलर मेथड होता है कि जो डाइनिंग फिलॉसफी
तरीके से यू नो वैलिडेट कर देता है जो डेड लॉक का प्रॉब्लम था उसको हटा देता है नाउ कमिंग टू नेक्स्ट प्रॉब्लम इज द स्लीपपिंग
बारबर प्रॉब्लम अब ऑलरेडी क्योंकि अभी हम काफी सारे यू नो क्लासिकल प्रॉब्लम डिस्कस कर चुके तो आई थिंक इसमें भी ज्यादा
प्रॉब्लम नहीं होगी पहले आपको डेफिनेशन समझाता हूं सो दिस इज अ बेसिकली सिनेरियो ऑफ अ बार्बर शॉप तो बड़ा मजेदार सिनेरियो
है जहां पर हमारे पास एक बार्बर है अगर बारबर खाली है तो वह सो जाएगा उसके पास अभी कोई काम नहीं है अगर कोई हेयर कट कर
कराने आएगा तो बारबर को वेकअप करेगा बार-बार हेयर कट करेगा यहां पर हमारे पास ए नंबर ऑफ वेटिंग चेयर्स भी हैं तो फॉर
एग्जांपल अगर कोई कस्टमर आता है और बार उस समय बिजी है हेयर कट कर रहा है तो वो कस्टमर एक चेयर ऑक्यूपाइड कर सकता है बट
अगेन जैसा आप देख रहे हैं वेट की भी एक लिमिट है अगर एक ऐसा सिनेरियो है कि कोई कस्टमर आता है जहां पे जितनी भी चेयर्स है
वो सब ऑक्यूपाइड है और बारबर भी ऑक्यूपाइड है तो कस्टमर बाहर चला जाता है अदर वाइज कस्टमर बैठ के वेट करेगा जैसे ही बार-बार
किसी का हेयर कट कंप्लीट करेगा कोई और कस्टमर जो वेट कर रहा होगा उसको उसका हेयर कटिंग होगा तो ये एक पूरा सिनेरियो है और
इसको हमें सिंक्रोनाइज करना है यूजिंग सीमा फोर्स तो जैसा मैं हर केस मैं कर रहा हूं सीधे प्रॉब्लम हमने समझ लिया आपको
सॉल्यूशन के ऊपर लेके चलता हूं बारबर कस्टमर दोनों हमारे पास है है ना पहले क्या-क्या रिसोर्सेस यूज कर रहे हैं एक
बार उसके बारे में जान लेते हैं तो यहां पर एक सीमा फोर है बारबर और बार्बर को इस बार हम उल्टा करेंगे इनिशिएटिव
बल है अगर वन है इसका मतलब बारबर अवेलेबल नहीं है यस देन वी हैव अ काउंटिंग सीमा फॉर कस्टमर जो इनिशिएटिव
में वेट कर कर रहे हैं अभी तो वो हमने कर लिया देन वी हैव अ टेक्स वन ये तो क्रिटिकल सेक्शन है अगेन एक टाइम पे कितने
जैसे वेटिंग एक नंबर होगा जो कि बताएगा वेटिंग कस्टमर कितने हैं तो उसको वेटिंग इज अ शेयर्ड वेरिएबल जैसे पहले रीड काउंट
वाली बात थी ना सेम है तो शेयर्ड वेरिएबल पे एक बार में एक से ज्यादा लोग काम करेंगे तो प्रॉब्लम हो सकता है उसको जो
सिक्योरिटी देगा वो देगा टेक्स तो किसी का भी कोड पहले देख सकते हैं लेट मी टेक द बर्बर वन तो यह देखिए वाइल ट्रू बर्बर
लगातार काम कर रहा है अब जैसे ही बर्बर काम करना ना शुरू करेगा देखिए सबसे पहले वेट करेगा कस्टमर को सोचिए अगर कोई वेटिंग
कस्टमर ही नहीं है तो बार-बार किसी का हेयर कट कर सकता है ओबवियसली नहीं कर सकता तो बहुत अच्छा सिंक्रोनाइजेशन है लेकिन
मान लेते हैं कि कुछ लोग वेट कर रहे हैं अब अगर कुछ लोग वेट कर रहे हैं लेट मी से कि इसका वैल्यू है थ्री यस यह भी यह सीमा
फोर है यह सिंपल वेरिएबल है बट दोनों का नंबर थ्री है तो वेट कर रहा है कस्टमर के लिए तो जैसे ही वेट करेगा मान लीजिए
वैल्यू हमारा हो गया टू सक्सेसफुल वेट ऑपरेशन एंड देयर यू सी यहां फ सिक्योरिटी क्योंकि अब हम एक आदमी का हेयर कट करना
शुरू करेंगे तो जो वेटिंग वाले हैं उनका काउंट एक कम होगा तो यह तो पहले से कम कर दिया बट वेटिंग को टच करने से पहले टेक्स
किया है तो टेक्स की वैल्यू को वन से करेंगे रो और वेट -1 तो जो वैल्यू यहां पर थ्री थी अब देखिए वो वैल्यू भी टू हो
जाएगी और उसके बाद सिग्नल कर रहा है बारबर को यस तो एक तरीके से मान लीजिए हेयर कट का प्रोसेस स्टार्ट कर दिया इनिशिएटिव
कर रहा है दोबारा टेक्स को ताकि इन इन बिटवीन अगर कोई और कस्टमर आए तो वो आ सके तो ये वैल्यू इसने वन कर दिया एंड लेट मी
से यहां पर हेयर कट बिगिन हो गया यस मान रहे कि हेयर कट चल रहा है कांटेक्ट स्विच होता है थोड़ा ध्यान देते हैं कस्टमर पे
अब क्योंकि उसने हेयर कट करने से पहले म्यूट्स कर दिया है सिग्नल को तो सिग्नल को सॉरी सिग्नल किया है टेक्स को तो अब
यहां पे कस्टमर आया उसने वैल्यू टेक्स की वन थी उसको जीरो किया अंदर गया चेक किया क्या वेटिंग n से कम है कि नहीं बिकॉज n
इज द मैक्सिमम काउंट कम है तो ही मैं आगे जा जा सकता हूं वरना था ना अगर सारे के सारे चेयर ऑक्यूपाइड है यहीं से बाहर हो
जाओ तो नहीं सर वेटिंग मान लेते हैं n से कम है लेट मी से वी हैव n नंबर ऑफ चेयर्स है ना तो वेटिंग का वैल्यू हमारा टू ही है
हां वेटिंग कम है अंदर गए वेटिंग प्लस प्लस तो अगेन वेटिंग दोबारा हमारा हो जाएगा थ्री क्योंकि एक और कस्टमर आया है
फेयर इनफ फिर सिग्नल करेंगे कस्टमर को वो भी काउंट टू था इसको भी उठा के हमने थ्री कर दिया दोनों बातें बिल्कुल सिंपल है मेक
सेंस और अब क्योंकि वेटिंग पे काम कर चुके हैं तो टेक्स को दोबारा वन कर देंगे ताकि अगेन कोई और अगर कस्टमर है तो काम कर सके
एंड देन दे यू सी वी आर गोइंग टू वेट द बार्बर अब बार्बर जो है उसका काउंट अभी हमारा वन है तो जैसे ही अभी ये हेयर कट
कंप्लीट होगा इसको हम वेट करेंगे और फिलहाल वैल्यू क्यों कि वन है तो वन को जीरो किया जा सकता है एंड देन वी गेट अवर
हेयर कट डन यस अगर वेटिंग बाहर ज्यादा होती मान लीजिए वेटिंग ऑलरेडी n पे जा चुकी होती तो हम यहीं से सिग्नल करते
टेक्स को यानी कि जो वन जीरो किया था उसको वन करते और बाहर चले जाते तो एक तरह का सिमिलर टाइप ऑफ़ सिनेरियो है
वेदर प्रोड्यूसर कंज्यूमर रीडर राइटर डाइनिंग फिलोसोफर और स्लीपिंग बार्बर हालांकि दिस इज नॉट दैट इंपॉर्टेंट बट इस
सब में से कोई ना कोई एक प्रॉब्लम तो पक्का आएगा तो व्हाट यू कैन डू इज दो-तीन बार कोड लिख के देखोगे इसकी मैथ साथ में
समझ लोगे तो फिर रटने की जरूरत भी नहीं पड़ेगी बात आपको ऐसे समझ आने लगेगी यस फेयर इनफ अब बात करते हैं हार्डवेयर
सॉल्यूशन की देखिए अभी जितने भी सॉल्यूशन हमने किए ना सिंक्रनाइजेशन के ये बेसिकली सॉफ्टवेयर सॉल्यूशन है सॉफ्टवेयर मतलब हम
कोई कोड लिख के चीजों को मैनेज कर रहे हैं बट क्या हार्डवेयर लेवल पर भी सिंक्रोनाइजेशन प्रॉब्लम को हैंडल किया जा
सकता है हां किया जा सकता है जैसे एक तो मैं डिटेल में जा भी नहीं रहा विच इज लाइक डिसेबल इंटरप्ट अगर आपका भोकाल इतना है यू
गो इनसाइड क्रिटिकल सेक्शन एंड देन यू जस्ट डिसेबल द इंटरप्ट कि अब कोई आपको इंटरप्ट कर ही नहीं सकता मैं पूरे इस
चैप्टर में एक बार बार-बार बोल रहा था ना क्या किसी भी प्रोसेस को कोई भी प्रोसेस कभी भी कांटेक्ट स्विच कर सकती है इन जनरल
वी से कि हां कर सकती है बट यहां पर मान रहे है कि नहीं कर सकती अब सोचिए अगर इंटरप्ट ही नहीं कर सकती तो अभी सोचो
इसमें फिर क्या आप करोगे क्या मैं करूंगा तो देन इट इज गोइंग टू वर्क फाइन और डिसेबल इंटरप्ट करो क्रिटिकल सेक्शन एंजॉय
करो बाहर आते हुए फिर से इनेबल कर दो तो यह एक अप्रोच हो सकती है एक दूसरा बहुत अच्छा मैकेनिज्म है जिसे बोलते हैं टेस्ट
एंड सेट वो कैसे काम करता है उस परे आपको क्लेरिटी देता हूं चार लाइन का छोटा सा कोड है वैसे इसमें पॉइंटर यूज हो रहे हैं
बट ट्रस्ट मी आप एक बार ऑब्जर्व करोगे आपको मजा आ जाएगा बहुत मुश्किल नहीं है मैं समझाऊ आपको पूरी बात एक कहानी समझो
टेस्ट एन सेट की इमेजिन करते हैं कि मेरे पास एक लॉक वेरिएबल है अभी मैं कोड की बात नहीं कर रहा एक बात आपको समझाता हूं मेरे
पास एक लॉग वेरिएबल है एंड लेट मी से लॉ की वैल्यू अगर ज़ीरो है तो लॉ फ्री है वरना वन है तो लॉग ऑक्यूपाइड है तो कोई
प्रोसेस आएगा और वो आके चेक करेगा इफ लॉग इ इ इ 0 इजंस ज़ीरो है वेल एंड गुड मैं क्रिटिकल सेक्शन के अंदर जाऊंगा सबसे पहले
लॉक में वन असाइन करूंगा ताकि किसी और को प्रॉब्लम ना हो आई विल एंजॉय माय क्रिटिकल सेक्शन और बाहर आते हुए नोटिस करिए लॉग को
दोबारा ज़ीरो करूंगा कितना सिंपल सा तीन लाइन का कोड है पूरी प्रोसेस कंप्लीट है कोई प्रोसेस आएगा चेक करेगा एंड दिस विल
गो ऑन प्रॉब्लम क्या है इसके अंदर इसको बोलते हैं टेस्ट एंड सेट करना हमने यहां पे पहले टेस्ट किया कि लॉक खाली है कि
नहीं लॉक खाली है तो अंदर गए लॉक एक्वायर किया क्रिटिकल सेक्शन एंजॉय किया बाहर आते हुए अनलॉक किया प्रॉब्लम इसके अंदर कब
आएगी वो ध्यान से देखिएगा मान लीजिए पहला प्रोसेस आता है लेट मी नेम दैट प्रोसेस p1 उसने पहले चेक किया लॉग की वैल्यू रो है
कि नहीं इधर अलग से मेंशन कर लेता हूं लेट मी से कि लॉग की वैल्यू रो है तो कोई प्रॉब्लम होनी नहीं चाहिए लॉक की वैल्यू
जीरो है प्रोसेस अंदर गया अब प्रोसेस लॉक = 1 करने वाला था टेस्ट कर चुका था सेट करने वाला था लेकिन किसी दूसरे प्रोसेस ने
मान लीजिए लेट मी से प्रोसेस नंबर p2 ने p1 को कांटेक्ट स्विच कर दिया अब सोचो क्या होगा जैसे ही कांटेक्ट स्विच हुआ तब
तक क्या लॉग की वैल्यू वन की जा चुकी थी नहीं की थी ओ माय गॉड p2 अंदर आया p2 ने चेक किया लॉग की वैल्यू अभी भी जीरो है p2
अंदर गया उसने लॉग की वैल्यू वन की और p2 p1 से पहले पहुंच गया क्रिटिकल सेक्शन के अंदर और आई थिंक आप समझ चुके होंगे कि
कैसे यहां पर ऑलरेडी म्यूचुअल एक्सक्लूजन वायलेट हो चुका है p1 को जब कंट्रोल वापस मिलेगा तो वो तो ऑलरेडी अंदर आ चुका है वो
क्या करेगा वो वन को कट करके दोबारा वन लिखेगा उसको लग रहा है लॉग की वैल्यू अभी भी ज़ीरो ही है और वो भी अंदर जाके p2 को
कर देगा पी से धप्पा धप्पा करेगा म्यूचुअल एक्सक्लूजन क्लियर कट वायलेट होता नजर आ रहा है क्योंकि एक ही टाइम पे दो प्रोसेस
क्रिटिकल सेक्शन के अंदर है सो दैट इज अ प्रॉब्लम बिहाइंड टेस्ट एंड सेट बेसिकली टेस्ट एंड सेट का ये मतलब होना चाहिए पहले
मैं टेस्ट करूंगा फिर मैं सेट करूंगा प्रॉब्लम क्या है ध्यान से सोचिए प्रॉब्लम यह है कि कोई तीसरा कोई दूसरा प्रोसेस आके
मुझे टेस्ट और सेट करने के बीच में कांटेक्ट स्विच कर रहा है अगर कोई प्रोसेस मुझे कांटेक्ट स्विच ना करे तो सॉल्यूशन
बढ़िया काम करेगा और वो कैसे करेगा इसी के लिए ये एक एग्जांपल यहां पर लिख के दिखाया है एक-एक प्रोसेस कंप्लीट करता हूं थोड़ा
सा इसमें यूज होगा पॉइंटर का बट आपको पॉइंटर आता है कि नहीं आता है प्रोग्रामिंग में आपकी क्या कैपेसिटी है
उस बात का इस क्वेश्चन से कोई लेना देना नहीं है तो बिल्कुल भी मत घबराइए यस मैं शुरू करता हूं देखिए हुआ क्या जैसे आमतौर
पे हम इंटरसेक्शन लिखते हैं वैसे ही इंटरसेक्शन है वाइल बाद में लगाया सेमीकलन इसका मतलब ट्रैप है वाइल टेस्ट एंड सेट और
क्या कर रहा है लॉग कोई वेरिएबल है उसका एड्रेस पास कर रहा है अब लॉग की कहानी आप जानते हैं तो लॉग मैं एक वेरिएबल बना लेता
हूं लेट मी टेक लॉक और यहां पे रो व ना बोल के आई थिंक ट्रू फॉल्स में लिखा है कोई दिक्कत नहीं है तो लॉक अगर फॉल्स है
तो मान लेते हैं कि अभी क्रिटिकल सेक्शन फ्री है लॉक फ्री है और जैसे कोई लॉक एक्वायर करेगा उसको उठा के ट्रू कर देगा
फेयर इनफ इतनी बात तो समझ आती है अब होगा क्या देखिए इसने एड्रेस पास किया वाइल टेस्ट एंड सेट में नाउ दिस इज अ फंक्शन
टेस्ट एंड सेट जहां पर एड्रेस आया एक पॉइंटर टारगेट में तो टारगेट का मतलब आप समझ रहे हो पॉइंटर का मतलब शॉर्ट में लिख
लेता हूं तो देर इज अ पॉइंटर टारगेट व्हिच पॉइंट्स टू लॉक चलिए यहां तक बात समझ आ गई अब क्या कह रहा है एक बुलियन वेरिएबल इसने
बनाया आरवी आरवी लेट मी से स्टैंड्स फॉर रिटर्न वैल्यू तो एक अलग से वेरिएबल बना लेता हूं आवी और उसमें क्या सेम कर रहा है
स्टार टारगेट तो टारगेट नहीं वही पॉइंटर वाली बात डी रेफरेंसिंग उसका वैल्यू जिसको ये पॉइंट कर रहा है तो लॉग का वैल्यू क्या
है फाइ ए फॉल्स तो यहां पे स्टार्ट टारगेट की मदद से क्लियर कट यहां पर हमने फॉल्स सेव कर लिया तो बेसिकली इस बार मैंने अभी
सेट नहीं किया ना ही टेस्ट किया मैंने उठा के सिर्फ वैल्यू को एक जगह कॉपी कर लिया और फिर यहीं बैठ के देखिए स्टार टारगेट
में रख रहा है ट्रू लॉग को मैंने टच ही नहीं किया लेकिन टारगेट प बैठ के स्टार टारगेट में ट्रू तो यहां पर इसका मतलब है
बिना पढ़े अभी हमने सिर्फ ल्ड वैल्यू सेव की है बिना पढ़े उसको ओवरराइट करके ट्रू कर दिया वाह भाई वाह अब कह रहा है रिटर्न
कर दो रिटर्न वैल्यू तो रिटर्न वैल्यू हमारे पास फॉल्स है अब बोलो वाइल में फॉल्स जाएगा तो क्या होगा लूप में फॉल
जाएगा तो कंडीशन वायलेट हो जाएगी आप लूप से बाहर आ जाएंगे और प्रोसेस लेट मी से यह p1 प्रोसेस है p1 बड़े आराम से पहुंचा
क्रिटिकल सेक्शन में मतलब तो समझो इस बात का अगर लॉग पहले से फॉल्स था सोचना इस बात को लॉग पहले से फॉल्स था तो कोई दिक्कत
नहीं होनी चाहिए लॉग ट्रू कर दिया मुझे क्रिटिकल सेक्शन में एंट्री मिल लीजिए मुझे क्रिटिकल सेक्शन में एंट्री मिल गई
बट मजे की बात क्या है पूरा पैटर्न ऑब्जर्व करें यहां मैंने पहले टेस्ट किया कि सेट किया यहां पहले मैंने सेट कर दिया
उसके बाद जाके टेस्ट किया पर सर अगर वैल्यू पहले से ट्रू होती करके देख लेते हैं p1 क्रिटिकल सेक्शन में है लेट मी से
कोई नया प्रोसेस आया जिसका नाम p2 प्रॉब्लम होनी चाहिए कायदे से तो p2 ने भी दोबारा कॉल किया टेस्ट एंड सेट और फिर से
ये पूरी कहानी चलेगी एड्रेस पास हुआ स्टार टारगेट इसने इसको पॉइंट फाइंड करना स्टार्ट किया इस बार बोलो रिटर्न वैल्यू
में क्या आएगा क्योंकि वैल्यू यहां पर ऑलरेडी ट्रू है इस बार रिटर्न वैल्यू में ट्रू आएगा स्टार टारगेट में ट्रू तो मैं
कुछ नहीं करूंगा ऑलरेडी ट्रू है ट्रू को ओवरराइट करके फिर से मैंने ट्रू लिख दिया एंड देन रिटर्न वैल्यू बट बोलो इस बार
क्या रिटर्न होगा सर इस बार ट्रू रिटर्न होगा क्योंकि वैल्यू पहले से ट्रू है और वाइल में अगर ट्रू बना रहेगा तो बोलो यहीं
पे वेट करूंगा बिजी वेट करूंगा आगे जाऊंगा सर यहीं पे गोलगोल घूमता रहूंगा तो p2 को क्रिटिकल सेक्शन में एंट्री मिलेगी कि
नहीं मिलेगी नहीं मिलेगी अब इसको आखिरी बार इंक्लूड कर देता हूं ऐसे मैं जाता हूं और बिना पढ़े जो भी लिखा है मेरे को फर्क
नहीं पड़ता उसको ट्रू कर देता हूं अगर वैल्यू पहले से फॉल्स है तो तो मेरा फायदा हुआ ना सर फायदा क्यों हुआ क्योंकि अब वो
वैल्यू हो गई ट्रू मेक्स सेंस मेरे को कंट्रोल मिल गया बाद में जाके मैंने एंट्री की लेकिन अगर वो वैल्यू पहले से
ट्रू है तो किसी का क्या नुकसान मैंने ट्रू को उठा के ट्रू ही रख दिया और मैं तो यहीं पे बिजी वेट कर रहा हूं अंदर तो जा
नहीं रहा सो दैट इज आईडिया ऑफ टेस्ट एंड सेट तो एक्चुअली इसका नाम टेस्ट एंड सेट है बट ये रियलिटी में क्या है ये सेट एंड
टेस्ट है सेट पहले कर रहे बाद में जाके टेस्ट करते हैं तो आई होप ये अप्रोच आपको समझ आई होगी और गेम क्या है कि जो पूरा
फंक्शनैलिटी है जो मैंने आपको पॉइंटर की मदद से बताया जो कॉम्प्लेक्शन होता है सिस्क कंप्यूटर खासकर जो होता है
कॉम्लेक्स कॉम्प्लेक्शन सेट फॉर्मेट कंप्लीट इंस्ट्रक्शन सेट फॉर्मेट वो इसको एटॉमिकली एग्जीक्यूट करते एक ऐसा
इंस्ट्रक्शन होना चाहिए कि बीच में मुझे कोई कांटेक्ट स्विच ना करे बिकॉज फिर वही टेस्ट एंड सेट की कांटेक्ट स्विच की
प्रॉब्लम है बीच में किसने कांटेक्ट स्विच कर दिया तो प्रॉब्लम होगा तो अगर मैं एटॉमिकली इसको रन करूं तो ये ये भी एक
सॉल्यूशन हो सकता है क्रिटिकल सेक्शन को अच्छे से हैंडल करने का सो आई होप अभी यह पूरी कहानी आपको समझ आई होगी टू प्रोसेस
सॉल्यूशन से लेके सीमा फोर क्लासिकल प्रॉब्लम तक और हार्डवेयर सॉल्यूशन तक ये सारे पॉइंट काइंड ऑफ हमने बहुत अच्छे से
स्टडी कर लिए एंड नाउ आई थिंक वी आर वेरी मच रेडी टू द लास्ट फेज ऑफ प्रोसेस मैनेजमेंट व्हिच इज डेडलॉक तो चलिए अभी
बात करते हैं डेडलॉक के बारे में डेडलॉक एक ऐसा सिनेरियो है जो पूरी कंप्यूटर साइंस में शब्द आप कई बार सुनेंगे बट
ट्रस्ट मी नॉट इवन डीबीएमएस ऑपरेटिंग सिस्टम ही ऐसा सब्जेक्ट है जहां पे आपको इसको डिटेल में पढ़ने का मौका मिलेगा तो
डेडलॉक का मतलब क्या है अगर इफ आई इफ आई गो बाय डेफिनेशन फिर एक छोटा सा एग्जांपल आपको समझाता हूं इन अ मल्टी प्रोग्रामिंग
एनवायरमेंट सेवरल प्रोसेस मे कंपीट फॉर फाइट नंबर ऑफ रिसोर्सेस ये बात तो ठीक है बहुत सारी प्रोसेसेस होंगी और बहुत सारे
रिसोर्सेस होंगे और प्रोसेस फाइट कर रही होंगी कि यार मेरे को रिसोर्स मिले ठीक है नाउ अब प्रोसेस रिक्वेस्ट अ रिसोर्स एंड
फिर रिसोर्स इज नॉट अवेलेबल एट द टाइम द प्रोसेस एंटर्स अ वेटिंग स्टेट ये बात भी समझ आती है
मैंने फॉर एग्जांपल यहां देखिए मान लीजिए दो प्रोसेस है p1 और p2 दो रिसोर्स r1 r2 फिलहाल मान लेते हैं कि प्रोसेस p1 को
दोनों रिसोर्स चाहिए और जैसे ही उसने रिक्वेस्ट किया r1 रिसोर्स जो है वो p1 को लोकेट हो गया लेकिन इसी टाइम पे p2 ने r2
रिसोर्स एक्वायर कर लिया यस अच्छा दोनों प्रोसेस को दोनों रिसोर्स चाहिए तो अब होगा क्या अगर मैं इसे डिफरेंट तरह से
मार्क करूं नाउ p1 विल बी वेटिंग फॉर रिसोर्स r2 एंड p2 विल बी वेटिंग फॉर रिसोर्स r1 दोनों वेट कर रहे हैं दोनों के
पास थोड़ा-थोड़ा आईडिया भी है तो अब हुआ क्या p1 वेटिंग में चला गया p1 से पूछ रहा भाई एग्जीक्यूट क्यों नहीं कर रहा p1 कह
रहा कैसे करूं क्योंकि मेरे को जो रिसोर्स चाहिए r2 व मेरे पास नहीं है हालांकि कुछ मैंने होल्ड भी करके रख ली है अब आप p2 से
पूछेंगे भाई आप रन कर लो p2 कहेगा मैं भी कैसे करूं मेरे को जो रिसोर्स चाहिए r1 वो मेरे पास नहीं है r2 मैंने एक्वायर कर लिए
बट r1 में क्या हो जब तक मैं वेटिंग में हूं जब तक मुझे r1 नहीं मिलेगा मैं आगे एग्जीक्यूट नहीं कर सकता दोनों यही बोल
रहे हैं नाउ सम टाइम्स वेटिंग प्रोसेस नेवर अगेन एबल टू चेंज द स्टेट बिकॉज़ द रिसोर्स इट हैज रिक्वेस्टेड इज होल्ड बाय
अनदर वेटिंग प्रोसेस एंड दिस सिनेरियो इज नोन एज डेड लॉग बात समझ आ रही है मैं वेट कर रहा हूं किसके लिए एक ऐसे प्रोसेस p2
के लिए जो कि काइंड ऑफ खुद वेट कर रहा है किसके लिए मेरे लिए बिकॉज़ अल्टीमेटली p1 देखने में लग रहा r2 के लिए वेट कर रहा है
बट एक्चुअली वो p2 के लिए वेट कर रहा है क्योंकि r2 p2 के पास है p2 r1 के लिए वेट कर रहा है बट एक्चुअली वो भी p1 के लिए
वेट कर रहा है क्योंकि r1 p1 के पास है सो सेट ऑफ प्रोसेस इज इन डेडलॉक स्टेट व्हेन एवरी प्रोसेस इन द स्टेट इज वेटिंग फॉर एन
इवेंट दैट कैन बी कॉज ओनली बाय अनदर प्रोसेस इन द सेट तो पढ़ने में थोड़ी बढ़िया लग रही है डेफिनेशन आईडिया क्या है
व सारी प्रोसेस मिला के डेडलॉक बना रही है कब जब प्रोसेस किसी ऐसे इवेंट के लिए वेट कर रहा हो जो वो प्रोसेस करे जो खुद
वेटिंग स्टेट में तो यह तो वेट कभी पूरा होगा नहीं तो यह फाइना इट स्टार हुआ कि इनफाइनों मैं बोल रहा हूं यहां देर नहीं
अंधेर है जब अंधेर हो तो मान लेना कि हां डेड लॉक लग गया तो डेड लॉक की बेसिक सिचुएशन आपको समझ आई अब जैसे देखिए
प्रैक्टिकल एग्जांपल देखिए इस कार से इन दोनों कार से बोलेंगे चल क्यों नहीं रहे बोलेगा यह चलेगा तो मैं चलू इन दोनों कार
से पूछोगे चल क्यों नहीं रहे बोलेगा यह कार अगर रास्ता दे ये दोनों कार तो मैं चलू इस कार से पूछोगे बोलेगा ये कार एंड
देन यू से देर इज अ साइकिल हां तो अल्टीमेटली ये सब के सब वेटिंग में है यह एक ऐसे इवेंट के लिए वेट कर रहे हैं जो
इनडायरेक्टली खुद आपके लिए वेट कर रहा है तो य लग गया डेड लॉक और ट्रैफिक तो बहुत पॉपुलर एग्जांपल है डेड लॉक का रियल लाइफ
में और बहुत सारे सिनेरियो हो सकते हैं जैसे मैंने एक एग्जांपल सोचने की कोशिश की इधर हमारी गवर्नमेंट ऑफ इंडिया इधर है
सिटीजन गवर्नमेंट क्या बोलती है गवर्नमेंट बोलती है कि हमें सिटीजन से टैक्स चाहिए है ना जब यह हमको प्रॉपर तरह से ईमानदारी
से टैक्स देंगे तो बदले में हम इनको सर्विसेस देंगे अब सिटीजंस क्या शिकायत करेंगे हमें सर्विस नहीं मिल रही गट क्या
शिकायत करेगी हमें टैक्स नहीं मिल रहा और दोनों एक दूसरे पे यू नो आरोप लगाते रहेंगे सो दिस इज अ काइंड ऑफ अ डेडलॉक
सिचुएशन और देख लेते हैं लुक एट दिस दिस इज एटम बम अब देखिए कितनी मजेदार बात है मान लीजिए कोई बड़ा बम है न्यूक्लियर बम
है जैसे जैसे हमने बड़े-बड़े वेपन सिस्टम्स बनाए ना दुनिया में तो लोगों को लग रहा था लड़ाई ज्यादा होगी बट एक्चुअली
उसके बाद लड़ाई हुई कि नहीं हुई नहीं बिकॉज एक तरह का डेडलॉक सिचुएशन है सबको पता है कि अगर इसके पास एटम बम है है ना
फॉर एग्जांपल एपल नॉर्थ कोरिया के पास भी एटम बम है तो अमेरिका को पता है अगर हमने नॉर्थ कोरिया को कुछ किया तो वो हम पे एटम
बम कर देगा इसलिए कोई कुछ कर नहीं रहा सो दिस इज आल्सो काइंड ऑफ अ डेड लॉक तो डेड लॉक का एक बेसिक अंडरस्टैंडिंग आई थिंक
आपको समझ आ गया डेड लॉक होता क्या है डेफिनेशन आप देख चुके एग्जाम में मस्त से लिख के आएंगे अब हमें ओबवियसली डेड लॉक
हटाना है डेड लॉक ऑपरेटिंग सिस्टम के लिए कंप्यूटर के लिए कोई बहुत अच्छा सिनेरियो नहीं है डेड लॉक हटाएंगे कैसे डेड लॉक
हटाने के लिए पहले ये समझना पड़ेगा कि डेड लॉक लगता क्यों है जब तक डेड लॉक यू नो समझेगा नहीं तब तक उसको हटाओ ग स तो यहां
पर पहले हम क्या स्टडी करते हैं अगेन दिस इज अ वेरी इंपोर्टेंट क्वेश्चन फॉर सेमेस्टर एग्जाम नेसेसरी कंडीशंस फॉर डेड
लॉक तो हमारे पास चार नेसेसरी कंडीशन इसको सीक्वेंस में याद कर लेना हाथ में टैटू करा लेना क्या-क्या हमारे पास है म्यूचुअल
एक्सक्लूजन होल्ड एंड वेट नो परमिशन एंड सर्कुलर वेट मैं रिपीट कर रहा हूं म्यूचुअल एक्सक्लूजन होल्ड एंड वेट नो
परमिशन सर्कुलर वेट कोई एक नहीं जब किसी सिस्टम में ये चारों कंडीशन एक साथ अकर करती हैं तो डेडलॉक लगता है तो पहले हम
क्या करना वाले पहले हम इन चारों कंडीशंस को समझने वाले हैं और फिर आगे जाकर समझेंगे कि ऐसा क्या करें कि ये चारों
कंडीशन एक साथ अगर ना करें तो डेड लॉक भी नहीं लगेगा है ना तो डेड लॉक ना लगे वो करने के लिए समझने के लिए वो इंप्लीमेंट
करने के लिए पहले हम ये समझ रहे कि डेड लॉक लगता कैसे तो सबसे पहला जो हमारा कंडीशन है व है म्यूचुअल एक्सक्लूजन सिंपल
भाषा में समझा देता हूं नोट सारा यहां पर मैंने लिख के रखा है एग्जाम में आपको क्या लिख के आना है देखो लड़ाई होने के लिए
पहले लड़ाई का एक कारण होना जरूरी है ना तो हम हमारे पास एक ऐसा रिसोर्स होना चाहिए लेट मी कॉल इट r1 जो कि म्यूचुअल
एक्सक्लूसिव फैशन में ये सीमा फोर वाले म्यूचुअल एक्सक्लूजन है वो अलग बात है अलग बात है म्यूचुअल एक्सक्लूसिव फैशन में ही
यूज होता हो कहने का मतलब क्या है अगर एक रिसोर्स है देखिए जैसे यहां पर मैंने प्रिंटर का एग्जांपल लिया मुझे बताइए कि
एक टाइम पे एक प्रिंटर को दो या तीन या चार लोग यूज कर सकते हैं क्या प्रैक्टिकली कैसे करेंगे एक टाइम प तो एक ही कर सकता
है बिकॉज फिजिकल नेचर उसका ऐसा है तो सपोज इफ समबे यूजिंग सम वायरलेस नेटवर्क तो अभी इन दोनों को क्या करना पड़ेगा वेट करना
पड़ेगा तब जब यह काम कंप्लीट हो जाएगा तब आगे बढ़ेगा अब मान लीजिए रेडियो है क्या हो सकता है यह तीनों लोग एक ही टाइम पे
रेडियो सुनना चाहते हो सुन सकते हैं रेडियो इज़ अ शेरेबल रिसोर्स तो उसमें कभी डेड लॉक लगेगा नहीं तो याद रखिएगा डेड लॉक
लगने के लिए एक कारण होना जरूरी है वह कारण क्या है मेरे पास कम से कम एक ऐसा रिसोर्स हो जो कि म्यूचुअल एक्सक्लूसिव
फैशन में यूज़ होता हो म्यूचुअल एक्सक्लूसिव मतलब एक बार में एक अगर ऐसा है तो डेड लॉक लग सकता है मैं नहीं कह रहा
हूं लगेगा तो लग सकता है बट अगर ये रिसोर्स नहीं है तो तो लगेगा ही नहीं बात तय हो गई समझ आती है बात आगे बढ़ी अगला
क्या है होल्ड एंड वेट अच्छा ये कमाल की सिचुएशन है एक एग्जांपल रिलेट करता हूं मान लीजिए आप गए किसी पार्टी के अंदर अब
पार्टी में आपको खाना है खाना इसीलिए आप गए हैं खाना खाने के लिए दो रिसोर्स आपको चाहिए एक प्लेट चाहिए एक स्पून चाहिए मैं
वो वाला केस इमेजिन नहीं कर रहा कि बिना इसके आप कैसे खाएंगे वो तो जबरदस्त हो जाएगा खैर दो रिसोर्स चाहिए अब मान लीजिए
आपको प्लेट तो मिला आपको स्पून नहीं मिली अब आप क्या करेंगे एक तरीका तो यह प्लेट भी वहां पर रखी हुई है और आप ढूंढ रहे हैं
स्पून की जब स्पून मिलेगी तभी आके प्लेट भी लूंगा वरना कोई मतलब नहीं है लेकिन मुझे बताइए ऐसा करने में एक ऑब्स यू नो एक
एक आईडिया है कि क्या हो सकता है इन द मीन वाइल आपको स्पून मिले आपकी प्लेट भी गायब हो जाए तो एक फंडामेंटल सिनेरियो क्या है
एक बेसिक बिहेवियर क्या है कि आप इस प्लेट को अपने हाथ में रखेंगे आप इसको होल्ड करेंगे और उसके बाद जाके रिमेनिंग रिसोर्स
के लिए वेट करेंगे इजेंट इट और हम मान के चलते हैं ऑपरेटिंग सिस्टम में जितनी भी प्रोसेस है सबका यही बिहेवियर है जिसको
बोलते हैं होल्ड एंड वेट तो जैसा हमने वहां देखा था ना अगर किसी प्रोसेस p1 को दो रिसोर्स चाहिए सपोज ली r1 एंड r2 और
मान लेता हूं कि r1 अभी अवेलेबल है तो p1 क्या करेगा p1 r1 को होल्ड करेगा उसके बाद r2 को सर्च करेगा होल्ड एंड वेट है ना p1
का आर्गुमेंट क्या है वच व्हिच मेक्स सेंस कि यार अगर मैंने इसको भी होल्ड नहीं किया ना तो मैं तो स्टार्वेशन में चला जाऊंगा
पता नहीं ऐसा कब होगा कि सारी रिसोर्स एक साथ मिलेंगी हालांकि ऐसा करने से डेड लॉक लगता है बट ये पॉइंट आपको समझना है तो
होल्ड एंड वेट की यू नो कंडीशन क्या कहती है प्रोसेस मस्ट बी होल्डिंग एटलीस्ट वन रिसोर्स एंड वेटिंग फॉर वेटिंग टू एक्वायर
एडिशनल रिसोर्सेस दैट आर नॉट दैट आर करेंटली हेल्ड बाय अदर प्रोसेस तो जो मिले भागते भूत की लंगोटी मिली जो मिले उसको
होल्ड करो उसके बाद आगे के लिए वेट करना है दैट इज होल्ड एंड वेट नेक्स्ट इज नो प्रीमन
इसका क्या मतलब है यहां देखिए दो रेसलर आपको नजर आ रहे हैं हालांकि आपको लगेगा कि यार बड़ी ना इल्लीगल सी इनवैलिड फाइट है
बिकॉज यह सुमो रेसलर काफी भारी नजर आ रहा है और यह तो एक बच्चा है हालांकि मैं आपको बता दूं सुमो रेसलिंग एक ऐसा स्पोर्ट है
जहां पे वेट कैटेगरी होती नहीं है तो ऑफिशियल इट्स अ लीगल फाइट बिकॉज आपको अगर जीतना तो आप भी अपना वेट बढ़ा लो
आर्गुमेंट ये है हालांकि इसमें जीतेगा यह बच्चा ही बिकॉज ये इसी का बच्चा है तो ये अपने बे को ट्रेन कर रहा है वो अलग बात है
चलो मैं आपको आईडिया समझाता हूं नो परमिशन क्या कहता है इन अ सिस्टम जब तक हम अलग से मेंशन नहीं करेंगे क्या कोई प्रोसेस किसी
दूसरे प्रोसेस का रिसोर्स फोर्सफुली प्रिंट कर सकता है क्या नहीं कर सकता सर बिकॉज़ आप समझिए ना सिनेरियो याद है सबसे
बेसिक एग्जांपल दो प्रोसेस है मेरे पास p1 p2 दो रिसोर्स है मेरे पास r1 r2 r1 p1 के पास है r2 p2 के पास है और अब हम बचे हुए
रिसोर्स के लिए क्या कर रहे हैं अब हम बचे हुए रिसोर्स के लिए वेट कर रहे हैं अगर फोर्सफुल प्रिमिस अलाउड हो अगर कोई
प्रोसेस किसी दूसरे प्रोसेस के रिसोर्स को फोर्सफुली प्रिंट करे तो कभी लड़ाई होगी सर फिर तो कभी क्लैश होगा ही नहीं वो
लड़के अपना मामला सेटल कर लेंगे तो नो प्रशन क्या कहता है हम किसी दूसरे प्रोसेस के रिसोर्स को फोर्सफुली प्रिम नहीं कर
सकते जब तक कि वो उसको वॉलेटर रिलीज ना कर दे तो परमिशन वाला आईडिया नहीं है है ना तो म्यूचुअल एक्सक्लूजन बात समझ आ गई
होल्ड एंड वेट समझ आ गया नो प्रशन समझ आ गया क्या इन तीनों कंडीशन से डेडलॉक लग जाएगा नहीं नहीं मैंने बोला चारों कंडीशन
जब एक टाइम पे एक साथ अगर होंगी तो डेड लॉक लगेगा और चौथ सबसे इंपॉर्टेंट कंडीशन है सर्कुलर वेट मैं एक बहुत सिंपल सा
सिनेरियो दिखा के आपको समझाता हूं मजा आ जाएगा मान लीजिए तीन प्रोसेस है लेट मी से p1 एंड p2 और ये एक तरह का बेसिक सा ग्राफ
है जो बता रहा है कौन किसके लिए वेट कर रहा है इसको बोलते हैं वेट फॉर ग्राफ तो लेट मी से इस सिनेरियो का मतलब है राइट
नाउ p1 इज वेटिंग फॉर p2 p न इज वेटिंग फॉर p1 एंड p1 इज वेटिंग फॉर p2 और p2 से फिलहाल कोई आउटगोइंग एज
नहीं है तो मेरे को समझ आ रहा है कि p2 शायद अभी किसी के लिए वेट नहीं कर रहा अब आईडिया बताइए क्या यहां पर म्यूचुअल
एक्सक्लूजन है सर 100% है क्योंकि अगर म्यूचुअल एक्सक्लूजन ना होता तो फिर p नॉ p1 के लिए या p1 p2 के लिए वेट क्यों करता
तब तो सारी रिसोर्स शेरेबल होती और एक टाइम पे एक से ज्यादा प्रोसेस रिसोर्स यूज कर पाते पॉइंट टू बी टेकन सेकंड होल्ड एंड
वेट क्या हो सकता है p0 और p1 ने कुछ रिसोर्स होल्ड भी करके रखी और तब एडिशनल रिसोर्स के लिए वेट कर रहे हूं हां
बिल्कुल हो सकता है कि सर कुछ रिसोर्स इनके पास हो अगेन दैट मेक्स सेंस कमिंग टू थर्ड पॉइंट क्या यहां पे नो प्रीमन भी है
हां क्योंकि अगर प्रीमन अलाउड होता तो अब तक वेट थोड़ी करते यार अब तक p नॉ p1 का या p1 p2 के रिसोर्स को फोर्सफुली प्रिंट
कर चुका होता हां या ना तीनों कंडीशन है पर क्या डेड लॉक है आई डोंट थिंक सो बिकॉज़ p2 किसी के लिए वेट नहीं कर रहा
कुछ समय के बाद p2 एग्जीक्यूट होगा रिसोर्स रिलीज करेगा वो रिसोर्स p1 को मिलेगा फिर p1 रन करेगा रिसोर्स रिलीज
करेगा वो रिसोर्स p0 को मिलेगा और कहानी खत्म हो जाएगी लेकिन सर अगर ऐसा हो जाए कि p2 फिर से घूम के p
न के लिए वेट करें फिर वही बात सर्कुलर वेट अब यह प्रॉब्लम कभी सॉल्व होने वाली नहीं बिकॉज़ हर कोई एक दूसरे के लिए ही
वेट कर रहा है तो आखिरी कंडीशन है सर्कुलर वेट ध्यान रखना है जब तक सर्कुलर वेट भी नहीं होगा तब तक भी डेड लॉक नहीं लगेगा तो
चारों कंडीशन आई थिंक हमने समझ ली है और बड़ा इंटरेस्टिंग सिनेरियो है याद रखिएगा यह इतना लिख दिया 10 में से आठ न नंबर
मिलेगा ही मिलेगा म्यूचुअल एक्सक्लूजन होल्ड एंड विट ो प्रशन सर्कुलर वेट जब ये चारों कंडीशन नेसेसरी है ना जब ये चारों
कंडीशन एक साथ अगर करती है तो डेट लॉक लगता है अब हमें करना क्या प्रॉब्लम तो समझ गए सर हमें करना है ये अब हमें डेड
लॉक की हैंडलिंग मेथड समझने है हमें समझना है कि ऐसा क्या करें कि डेड लॉक ना लगे अब ऐसा करने की बेसिकली चार अप्रोचेबिलिटी
सिस्टम डिजाइन करो कि डेड लॉक लगे ही ना लगना ही नहीं चाहिए नेक्स्ट इज अवॉइडेंस मैं धीरे-धीरे पार्शियल डिफरेंस से समझाऊं
अवॉइडेंस इतना एग्रेसिव नहीं है जितना एग्रेसिव प्रिवेंशन अवॉइडेंस कहता है रन टाइम पे मैनेज कर सकते हैं क्या लगने हम
भी नहीं देंगे लेकिन इतने स्ट्रिक्ट नहीं होंगे जितना कि प्रिवेंशन होगा नेक्स्ट इज डिटेक्शन वो कहता है टेंशन क्या भाई पहले
लग जाने दो अभी पहले से टेंशन नहीं लेते ये बहुत ही लिबल है कह रहा पहले लग जाने दो अगर लगा तो रिकवर कर लेंगे सो दैट इज
डिटेक्शन एंड रिकवरी एंड फोर्थ क्या है इग्नोर हैंस यह ध्यान में है आत्मा यू नो अजर अमर है यह वो वाले सिद्धांत पर काम कर
रहा है कह रहा है डेडलॉक क्या होता है मन के मानो तो डेड लॉक है मन से नहीं मानो तो डेड लॉक नहीं है तो अगर मैं इसे इग्नोर ही
कर दूं प्रॉब्लम को तो फिर प्रॉब्लम सॉल्व करने की जरूरत नहीं है थोड़ा जीब भी लगता है बट ये बहुत इंपॉर्टेंट आईडिया किसी
प्रॉब्लम को सॉल्व करने का इस पे भी आगे डिटेल में बात करेंगे यस तो अब पहले सबसे पहले आपको समझाता हूं प्रिवेंशन अप्रोच
कैसे काम करता है तो चलिए सबसे पहले बात करेंगे प्रिवेंशन के बारे में बहुत बार आपने सुना होगा प्रिवेंट इज बेटर देन
क्योर है ना तो अगर पहले से रोका जा सकता प्रॉब्लम को तो सॉल्व कर लेना चाहिए और मेरे ख्याल से पोलियो से बड़ा एग्जांपल
क्या हो सकता है आजकल हालांकि मुझे पता नहीं नए लोग कितना जानते हैं बट पोलियो वैक्सीन पोलियो एक बहुत बड़ी प्रॉब्लम थी
और इंडिया जैसे इतने बड़े देश में पोलियो काफी लोगों को हो रहा था तो गवर्नमेंट ने क्या किया वैक्सीनेशन शुरू किया होने का
इंतजार नहीं किया बिकॉज एक बार अगर किसी को पोलियो हो गया तो फिर गया फिर उसका कोई सॉल्यूशन नहीं है तो इतने सारे लोगों को
वैक्सीनेशन दी और बिकॉज ऑफ दिस ओनली नाउ इंडिया इज प्रैक्टिकली अ पोलियो फ्री नेशन है ना तो प्रॉब्लम अगर बहुत सीवियर नेचर
का और बार-बार हो रहा है तो बेटर है कि उस प्रॉब्लम को पहले ही रिमूव कर दिया जाए अब क्या यह सॉल्यूशन डेड लॉक पे लगाया जा
सकता है हां दोबारा सोचते हैं एक बार डेड लॉक कब लगता है जब चार कंडीशन एक साथ हो है ना कौन-कौन सी नो प्रीमन सॉरी सबसे
पहले म्यूचुअल एक्सक्लूजन होना चाहिए देन होल्ड एंड वेट होना चाहिए नो परमिशन सर्कुलर वेट एक कुर्सी है जिसके चार पाए
हैं अगर उसमें से एक लेग भी तोड़ दिया जाए तो डेडलॉक बैठ पा पाएगा क्या नहीं डेड लॉक गिर जाएगा तो चलिए वही शुरू करते हैं सबसे
पहला जो हमारा कंडीशन था म्यूचुअल एक्सक्लूजन था क्या म्यूचुअल एक्सक्लूजन कंडीशन को वायलेट किया जा सकता है हटाया
जा सकता है बहुत सोचेंगे तो समझ आएगा नहीं क्यों क्योंकि म्यूचुअल एक्सक्लूजन जो है ना वो दरअसल किसी भी रिसोर्स का फिजिकल
नेचर है अब जैसे मान लीजिए प्रिंटर है प्रिंटर कहता है भाई मैं एक बार में एक ही पेज प्रिंट कर सकता हूं तो या तो ये भाई
साहब करेंगे ये मैडम करें ये करेंगे तीनों का मैं एक साथ तो नहीं कर सकता अब मैं इसमें कोई भी मैनेजमेंट लगा लू यहां तो हम
बेसिकली सॉफ्टवेयर सॉल्यूशन लिख रहे हैं ना मैं कोई भी सॉल्यूशन लगा लूं मैं प्रिंटर को शेरेबल बना पाऊंगा क्या एक
टाइम पे तो नहीं हो सकता ना सर एक के बाद दूसरा दूसरे के बाद तीसरा करा सकते हैं तो इसका मतलब हम कितना भी दिमाग क्यों ना
लगाएं बट रिसोर्स अगर ऐसे नेचर का है जो कि म्यूचुअल एक्सक्लूसिव फैशन में यूज होता है तो मैं कुछ भी करके उसको शेरेबल
नहीं बना सकता तो इसका मतलब थोड़ा अजीब है बट क्या आप म्यूचुअल एक्सक्लूजन को प्रिवेंशन के अंदर वायलेट कर सकते हैं
नहीं कर सकते कोई बात नहीं अभी तीन पाए और बचे हैं अगला कोशिश करते हैं होल्ड एंड वेट इस पर बहुत सारी
अप्रोचेबल किसी रिसोर्स को होल्ड करके बैठ जाएगा और उसके बाद एडिशनल रिसोर्स के लिए वेट करेगा चलिए इस कंडीशन को वायलेट करते
हैं पहला एक आइडिया कंजरवेटिव अप्रोच जहां पर हम क्या बोलते हैं याद है ये वाला एग्जांपल कि प्रोसेस p1 कह रहा है कि यार
r1 तो मैंने होल्ड कर ली है r2 के लिए अभी मैं वेट कर रहा हूं और मैंने गेम चालू कर दिया प्रॉब्लम हो गया हम बोलेंगे नहीं
प्रोसेस इज अलाउड टू रन इफ एंड ओनली इफ इट हैज अक्वायर्ड ऑल द रिसोर्स सोर्सेस तो बेटा जितने रिसोर्स चाहिए पहले ले ले r1
लिया r2 चाहिए तो r2 भी जब आप एक्वायर कर लोगे तभी आप एग्जीक्यूशन चालू करोगे वरना r1 भी वापस ले लेंगे या तो ऑल या तो नन तो
ये इसलिए इसका नाम है कंजरवेटिव थोड़ी पुरानी बात है कि जब तक सारी रिसोर्स नहीं मिलेंगी तब तक रन करने नहीं देंगे बट कम
से कम रन टाइम प प्रॉब्लम नहीं आएगी तब होगा क्या r1 के बाद r2 के लिए ट्राई करेगा अगर r2 मिला तो बढ़िया बट अगर नहीं
मिला तो अब r1 को भी रिलीज करना पड़ेगा वो किसी और को मिलेगा तो अल्टीमेटली डेड लॉक नहीं लगेगा तो होल्ड एंड वड को वायलेट
किया जा सकता है बट इस सॉल्यूशन की कॉस्टिंग थोड़ी ज्यादा है एक प्रैक्टिकल सॉल्यूशन भी है वो क्या है अल्टरनेटिव
प्रोटोकॉल यह क्या कहता है कंक्लूजन यह है यह कहता है आपको जो रिसोर्स चाहिए आप सारे मत लो ठीक है आपको r1 चाहिए ना भी आप r1
लो और रन करना स्टार्ट करो ऐसा भी तो हो सकता है ना कि सारे रिसोर्स एक टाइम पे नहीं चाहिए मान लीजिए यह सीपीयू है यह
प्रिंटर है प्रोसेस कहता है पहले मेरे को एक घंटा कुछ कंप्यूटेशन करना है बाद में जो रिजल्ट आएगा उसको मेरे को प्रिंट कराना
है अब आप बोल रहे हो कि प्रिंट पहले से होल्ड करके रख एक घंटा कोई सेंस नहीं है कोई और आदमी यूज कर लेगा तो लॉजिक क्या
कहता है यहां पे कहता है जो रिसोर्स आपको चाहिए आप उसे एक्वायर करो काम करना चालू करो यस लेकिन उसके बाद किस बात का ध्यान
रखना है जब भी आप कोई दूसरा रिसोर्स के लिए रिक्वेस्ट करोगे पहले आपको जो रिसोर्स अभी आपको लोकेटेड है पहले आपको वो भी
रिलीज करनी पड़ेंगी जब वो रिलीज करोगे देन ओनली यू कैन हैव अ फ्रेश रिक्वेस्ट बताओ बात समझ आती है क्या तो जो रिसोर्स है वो
रिलीज करो तभी एडिशनल रिक्वेस्ट कर सकोगे अब होगा क्या जब यह रिलीज करोगे r1 रिलीज करोगे और r2 मांगोगे अब दो चीज होंगी या
तो r1 r2 दोनों आपको मिल जाएगा या तो हो सकता है r1 भी चला जाए कि r2 तो मिला नहीं जैसे ही r1 रिलीज किया वो कोई और ले गया
स्टार्वेशन हो सकता है बट कम सेकम सिस्टम में तो डेड लॉक नहीं लगेगा क्योंकि यह r1 किसी और को मिलेगा जो मिलेगा वो रन करेगा
रन करेगा रिसोर्स रिलीज करेगा रिलीज करेगा फिर आपका नंबर आ जाएगा यस ना कमिंग टू द लास्ट सॉल्यूशन व इज कॉल्ड टाइम वेट वेट
टाइम आउटस इसका क्या मतलब मतलब है आप r1 होल्ड कर लो देन यू कैन वेट फॉर r2 बट यह जो होल्ड है ना सर ये
इनफाइनों अगर आपने रिसोर्स एक्वायर कर लिया तो ठीक है वरना फिर आपको रिलीज करना पड़ेगा फिर वही बात है डरो मत जब आप रिलीज
करोगे तो किसी और को मिलेगा जब वो रन करेगा तो फिर बाद में वो रिलीज करेगा तो आपको मिल जाएगा तो वेट के ऊपर एक मैक्सिमम
बाउंड अगर हम लगा दें कि इतने टाइम के अंदर या तो प्रॉब्लम सॉल्व करो वरना ये कहानी ऐसी च लेी तो भी आई थिंक ये
प्रॉब्लम हमारी सॉल्व हो जाएगी यस तो दैट इज हाउ वी कैन रिमूव होल्डन विट अलग-अलग अप्रोचेबल को सॉल्व किया जा सकता है इसमें
से एक भी आपने किया तो एक ऐसा सिस्टम बनेगा जिसमें कभी डेड लॉक नहीं लगेगा कमिंग टू द नेक्स्ट सॉल्यूशन नो प्रीमन अब
इसका क्या मतलब है सर कोई भी प्रोसेस किसी दूसरे प्रोसेस की रिसोर्स को फोर्सफुली प्रिंट नहीं कर सकता तो क्या करें कर लो
प्रिंट खत्म हो गई बात तो अब होगा क्या मैंने स्टेप बाय स्टेप फैशन में लिखा है हम अगर किसी ने कोई रिसोर्स रिक्वेस्ट
किया हम चेक करेंगे अवेलेबल है कि नहीं अगर अवेलेबल है लोकेट कर देंगे बात खत्म अगर अवेलेबल नहीं है तो क्या करना है अब
सिर्फ वेट नहीं करेंगे दो-तीन सिनेरियो लिखता हूं एक केस हो सकता है कि हमने उसको एलोकेट किया हुआ है लेकिन एक ऐसी प्रोसेस
को एलोकेट किया है जो खुद किसी और के लिए वेट कर रही है जो कि डेड लॉक का सिनेरियो है तो उस केस में हम अलाव कर देते हैं कि
चलो आप फोर्सफुली उसका रिसोर्स प्रिंट कर सकते हो बिकॉज हमें पता है भला तो उसका भी नहीं होना वो भी वेट ही कर रहा है तो आपने
उसका रिसोर्स प्रिंट कर लिया उसके बाद यूज़ किया यूज़ करने के बाद आप रिलीज करेंगे तो उसका भी नंबर आ जाएगा लेकिन अब
यहां पे एक पॉइंट होगा कि हर कोई दूसरे का रिसोर्स छीन रहा होगा वो कह रहा मैं तेरा छीन लेता हूं तो यहां पर एक चीज का ध्यान
रखना चाहिए वो है प्रायोरिटी तो उस हिसाब से हम देखेंगे कि हाई प्रायोरिटी प्रोसेस लो प्रायोरिटी प्रोसेस का वेटिंग प्रोसेस
का रिसोर्स प्रिंट कर सकता है बट वाइज वर्सा ना हो कि लो प्रायोरिटी हाई प्रायोरिटी का रिसोर्स प्रिंट कर ले इट्स
लाइक कि आपको कहीं जल्दी में जाना है तो आपने पीएमओ को फोन कर दिया कि मोदी जी अभी रुको थोड़ा मेरे को एक गाड़ी भेजो मेरे को
कहीं जल्दी जाना है समथिंग लाइक दिस ये नहीं होना चाहिए नाउ कमिंग टू द नेक्स्ट पॉइंट अगर आप वेटिंग में है आपको जो
रिसोर्स चाहिए वो किसी ऐसे आदमी के पास है जो खुद रनिंग में है तो पहले तो इट इज नॉट एडवाइजेबल कि रनिंग प्रोसेस का रिसोर्स
प्रिंट किया जाए बट अगेन एक पॉइंट हो सकता है फिर वही बात है प्रायोरिटी इफ यू आर अ वेरी हाई प्रायोरिटी प्रोसेस तो ये भी
अलाव किया जा सकता है कि रनिंग प्रोसेस को रोक दिया जाए उसका रिसोर्स प्रिंट कर लिया जाए और तब आपको रिसोर्स एलोकेट करके आपको
पहले रन कराया जाए डिपेंडिंग ऑन द प्रायोरिटी बट मरल स्टोरी कि यस नो प्रिम कहता था रिसोर्स प्रिम नहीं किए जा सकते
हम कहते रिसोर्स प्रिम कर सकते हो और इस तरह से भी डेडलॉक हमारा सॉल्व हो जाएगा यस नाउ कमिंग टू फुल एंड फाइनल सॉल्यूशन
सर्कुलर वेट ये बड़े कमाल का सॉल्यूशन है इसको कैसे वायलेट करते हैं कई बार बच्चों को समझ नहीं आता अ हर स्लाइड प मैं पूरा
थ्योरी लिख के रखा हूं तो यू कैन टेक अ स्क्रीनशॉट नोट डाउन ईच एंड एवरी पॉइंट राइट देम नाउ कमिंग हियर मान लीजिए हमने
क्या सिनेरियो देखा था एक रिसोर्स है r1 एक रि सोर्स है r2 दो प्रोसेस हमारे पास थे p1 और p2 और प्रॉब्लम क्या है कि दोनों
ने एक-एक रिसोर्स एक्वायर कर लिया अच्छा इधर मैंने रिसोर्स बना दिया चलो ठीक है तो लेट मी से ये रिसोर्स p1 के पास है ये
रिसोर्स p2 के पास है और अब दोनों प्रोसेस एडिशनल रिसोर्स के लिए वेट कर रहे हैं तो हम एक काम करते हैं प्रॉब्लम ये हुआ कि p1
ने तो r1 लिया इन द मीन वाइल मौके का फायदा उठाया मौके पे चौका मारा और p2 ने r2 ले लिया इनका ऑर्डर सेम कर दो ना ताकि
प्रॉब्लम ना हो ऑर्डर सेम कर दो सर इसका क्या मतलब है इसका मतलब यह है कि अगर दोनों प्रोसेस को
दोनों रिसोर्स चाहिए तो बोलो भाई पहले r1 ही लो उसके बाद r2 लेना क्लैश होना चाहिए अब होगा क्या देखो r1 या तो p1 को मिलेगा
या तो p2 को हमने दोनों को बता दिया अगर आपको r1 r2 चाहिए लेट मी से यू कैन रिक्वेस्ट फॉर द रिसोर्स ओनली इन द
इंक्रीजिंग नंबर पहले r1 लोगे तभी r2 लोगे जब तक r1 नहीं लोगे तब तक r2 नहीं ले सकते अब मेरे को तो नहीं पता r1 किसको मिलेगा
बट किसी एक को मिलेगा ना दो को तो नहीं मिल सकता मान लो r1 मिल गया p2 को अब r1 अगर p2 को मिला तो p1 r2 पे तब तक नहीं
जाएगा जब तक उसे r1 नहीं मिल रहा r1 उसे मिला नहीं तो अब बहुत आराम से r2 भी किसको मिलेगा p2 को मिलेगा डेड लॉक रिजॉल्व हो
गया सर्कुलर वेट को वायलेट कर देना है तो कंक्लूजन बोलूं जितने भी रिसोर्सेस है लेट मी से आई हैव 100 नंबर ऑफ रिसोर्सेस यू
नंबर ईच एंड एवरी रिसोर्स और हर प्रोसेस को जो जो नंबर चाहिए मान लीजिए कोई प्रोसेस है प्रोसेस नंबर प्रोसेस नंबर 32
कह रहा मेरे को रिसोर्स नंबर टू चाहिए रिसोर्स नंबर 12 चाहिए रिसोर्स नंबर 17 चाहिए रिसोर्स नंबर 23 चाहिए हम कह रहे सब
कुछ देंगे बट ऑर्डर में पहले वन लोगे फिर टू लोगे फिर 17 लोगे फिर 23 लोगे समथिंग लाइक दिस जो ऑर्डर आपने मेंशन किया है उसी
ऑर्डर में रिक्वेस्ट एलोकेट करेंगे और मैं आपको समझा पा रहा हूं अगर ऑर्डर एक पैटर्न में चलेगा तो इट एक्चुअली बिकम अ ड
डायरेक्ट अ साइक्लिक ग्राफ इसमें साइकिल बन ही नहीं सकती और साइकिल बनेगी नहीं तो डेड लॉक लगेगा नहीं तो चार में से
एक्सक्लूजन तो काम नहीं किया लेकिन बाकी तीन कंडीशन है ना याद करते रहिए होल्ड एंड वेट नो परमिशन सर्कुलर वेट इन सबसे डेड
लॉक रिजॉल्व किया जाता है और अगर रिजॉल्व इन तरीके से हम करते हैं उसको बोलते हैं प्रिवेंशन अप्रोच प्रिवेंशन का प्रॉब्लम
क्या है धीरे-धीरे समय के साथ हमें समझता है प्रिवेंशन ना कुछ इस तरह के रेगुलेशन लगा देता है बेसिकली कि यार इसकी कॉस्टिंग
बहुत ज्यादा है अब आप बोल रहे हो एक नंबरिंग करना इसमें कितना दिमाग लगाना पड़ेगा एल्गोरिथम इंप्लीमेंट कैसे होगा आप
बोल रहे हो कि फॉर एग्जांपल फोर्सफुल प्रशन कर लो रिसोर्स का इसकी कॉस्टिंग बहुत ज्यादा है आप बोल रहे हो होल्ड एंड
वेट अलाउ नहीं करेंगे या सारे रि सोर्स पहले एक्वायर करो यहां पे बेसिकली कंक्रेंस बहुत वीक हो जाएगी बिकॉज़ लोग
ऐसी ऐसे रिसोर्स होल्ड करके बैठे होंगे जो इस्तेमाल नहीं कर रहे हैं तो एक एग्जांपल क्या है कोविड का टाइम था जब कोविड आया
आया था आपको याद होगा स्टार्टिंग में गवर्नमेंट ने टोटल लॉकडाउन लगा दिया करते भी क्या मैं नहीं कह रहा गलत था उस समय
समझ ही नहीं आ रहा था लेकिन टोटल लॉकडाउन एक सॉल्यूशन तो था लेकिन इसकी कॉस्टिंग बहुत ज्यादा थी एकदम आप कर्फ्यू लगा देंगे
तो 10 15 20 दिन तो चला लिया हमने फिर हमको समझ आया लोगों को खाना भी देना जरूरत का सामान देना है मेडिकल प्रॉब्लम्स है
कैसे प्रॉब्लम सॉल्व होगी तो हमें समझ आया यार प्रिवेंशन सॉल्यूशन तो काम कर रहा है बट इसका कॉस्टिंग बहुत ज्यादा है थोड़ा
लिबरे होते हैं प्रॉब्लम भी इतनी सीरियस नहीं लग रही रिलेटिवली कि सब मर जाएंगे ऐसा नहीं लग रहा लेट्स गो फॉर अवॉइडेंस
कर्फ्यू रिलीज कर देते और कुछ समय बाद लोगों को खुद समझ आ गया कि भाई बचना है ये वो लोग हैं जिनके पास शायद मास्क भी नहीं
है बट दे आर यूजिंग देयर हैकी रुमाल कुछ भी यूज करके मैनेज कर रहा है क्यों पता है भाई मर जाओगे यस और नो ध्यान नहीं रखोगे
तो सो अवॉइडेंस इज एन आईडिया व्हिच इज नॉट दैट एक्सट्रीम लाइक प्रिवेंशन थोड़ा लिबरल है और रन टाइम पर प्रॉब्लम मैनेज करने की
कोशिश करता है जहां पर एक बहुत इंपॉर्टेंट एल्गोरिथम हम पढ़ना है बैंकर्स तो कैसे काम करता है अवॉइडेंस चलिए देखते हैं तो
चलिए अभी बात करते हैं अवॉइडेंस के बारे में और जैसा हमने समझा कि अवॉइडेंस उतना रिस्ट्रिक्टिव नहीं है जितना
रिस्ट्रिक्टिव प्रिवेंशन था कैसे काम करते हैं देखते हैं यहां देखिए एक बैंकर्स वाला यू नो आईडिया डिस्कस करता हूं बिकॉज
एक्चुअली एल्गोरिथम का नाम ही बैंकर्स एल्गोरिथम है क्या दिखाना चाह रहा हूं देखो जैसे देश को चलाने के लिए एक हिसाब
किताब रखने की जरूरत है है ना और फाइनेंस मिनिस्ट्री पूरे साल का बजट लेकर यहां पर नजर आ रही है इसका मतलब क्या देखिए देश की
कुछ कमाई है कुछ खर्चा है अगर कमाई बहुत ज्यादा हो और खर्चा बिल्कुल ना हो तो पैसा वेस्ट होगा बिकॉज हम उसे डेवलपमेंट के काम
में हेल्थ में डिफेंस में जगह-जगह यूज करना चाहिए अगर अगले साल और ज्यादा पैसा कमाना चाहते हैं अगर कमाई बहुत कम है और
खर्चा बहुत ज्यादा कर दिया तो भी हम डूबने वाले हैं तो चाहे व हमारा अपना घर हो आप सबके हमारे घरों में भी एक हिसाब किताब तो
रखा जाता है ना कितना खर्चा कर रहे हैं कैसे मैनेज करेंगे कुछ इमरजेंसी होगी तो उस समय कौन सा फंड काम आएगा हर कोई सोच के
चलता है उसी तरह देश भी सोच के चलता है अपना हिसाब किताब रखता है यही आईडिया अगर हम सिस्टम में यूज करें पूरा हिसाब किताब
रखें एक टाइम पे कितनी प्रोसेस मना किसी को नहीं कर रहे एक टाइम पे कितनी प्रोसेस है टोटल कितने रिसोर्स हैं कौन सी प्रोसेस
कितने रिसोर्स यूज कर सकती है कितने कर चुकी है क्या उसकी डिमांड हो गई अगर टाइम प कुछ और मांगेगी हम मैनेज कर पाएंगे नहीं
कर पाएंगे और यह सारा हिसाब किताब हम रखना शुरू कर दें तो इस पूरी अप्रोच को बोलते हैं बैंकर्स एल्गोरिथम या अवॉइडेंस मेथड
तो ये मेरे ख्याल से इसकी बैकग्राउंड मैंने आपको समझा दी है कि टोटल मैनेजमेंट करना अब करते कैसे देखिए छोटा सा मैं
आईडिया समझाता हूं क्योंकि पूरा हिसाब किताब रखना है तो यहां पर बहुत सारे डाटा स्ट्रक्चर्स या इंफॉर्मेशन हम मेंटेन करनी
पड़ती है एक मैट्रिक्स अच्छा मैट्रिक्स के अलग-अलग नाम हो सकते हैं तो घबराइए मत डिमांड कह ले नीड कह ले आप समझ जाएंगे तो
पहले एक मैट्रिक्स है जिसको बोलते हैं मैक्सिमम नीड मैट्रिक्स या मैक्स डिमांड मैट्रिक्स जब भी कोई प्रोसेस आएगा मान
लीजिए इस सिस्टम के अंदर तीन तरह की रिसोर्सेस हैं ए e और जी है ना ई e ए और जी तो मान लीजिए यहां पर लिखा हुआ है 3 2
और 7 फॉर एग्जांपल तो प्रोसेस p न कह रहा है किसी भी इंस्टेंस पे मैं e का मैक्सिमम थ्री रिसोर्स मांग सकता हूं f का मैक्सिमम
टू रिसोर्स मांग सकता हूं g का मैक्सिमम सेवन रिसोर्स मांग सकता हूं समथिंग लाइक दिस तो ये एक मैट्रिक्स पहले जब भी
प्रोसेस सिस्टम एंटर करेगी अपनी मैक्सिमम डिमांड हमें बताएगी पॉइंट नंबर वन पॉइंट नंबर टू किसी इंस्टेंस पे हम उसको क्या दे
चुके हैं ये भी एक किताब में लिख के रखेंगे मान लीजिए यहां पर लिखा है 112 क्या मतलब हुआ इस बात का कि प्रोसेस p नॉ
को e टाइप का एक रिसोर्स ऑलरेडी दिया जा चुका है f टाइप का भी एक रिसोर्स दे चुके हैं और g टाइप के दो रिसोर्स दे चुके हैं
अब ये दोनों एनालिसिस से हम क्या निकाल सकते हैं करंट डिमांड निकाल सकते हैं या करंट नीड निकाल सकते हैं तो तीन चाहिए थी
एक दे चुका हूं अभी कितनी डिमांड बची है दो दो चाहिए था एक दे चुका हूं अभी कितना डिमांड बचा है वन सेवन चाहिए था टू दे
चुका हूं अभी कितना डिमांड बचा है फाइव तो इस तरह से ये करंट नीड निकाल सकते हैं सिस्टम मैक्स जब गेम शुरू हुआ तो हमारे
पास क्या था मान लीजिए सिस्टम कह रहा है मेरे पास तो तीनों के 1010 रिसोर्स थे फॉर एग्जांपल और मैं क्या-क्या लोकेट कर चुका
हूं तो वो कह रहा है फिलहाल अगर देखें तो यही है लोकेशन तो यही है इसको माइनस कर दीजिए तो 10 था एक दे चुका हूं मेरे पास
भी कितना बचा हुआ है नाइन 10 था वन दे चुका हूं मेरे पास कितना बचा हुआ है नाइन 10 था टू दे चुका हूं मेरे पास कितना बचा
है एट तो ये आपको एक आईडिया समझ आया होगा प्रोसेस से इंफॉर्मेशन लेंगे रन टाइम पे पूरा हिसाब किताब मैनेज करेंगे और फिर
देखेंगे किसी भी सिनेरियो पे हम डेड लॉक में है कि नहीं है आईडिया क्या है स्पेसिफिकली रन कैसे करते हैं देखिए एक
छोटा सा डेटा सेट मैंने बनाया है और एल्गोरिथम को स्टेप बाय स्टेप भी आपको रन करके दिखा दूंगा बट बेसिक आईडिया यही
समझिए बैंक का तो यहां पर आप देख रहे हैं एक सिस्टम है जिसका सिस्टम के पास टोटल कितनी रिसोर्सेस है सिस्टम मैक्स आपको नजर
आ रहा है हर प्रोसेस का मैक्स डिमांड एलोकेशन मेरे पास है अब अगर मैक्स डिमांड और एलोकेशन आपके पास है तो आप क्या निकाल
सकते हैं करंट नीड निकाल सकते हैं चलिए मेरी मदद करिए माइनस करके बताइए तो 431 मैक्स डिमांड था 101 ऑलरेडी एलोकेटेड है
तो कितना बचा आई थिंक 4 - 1 इज लाइक थ्री या मैं आई थिंक मैंने बना के रखा है कि नहीं बना के रखा ओके 4 - 1 इज 3 3 - 0 इज
3 एंड 1 - 1 इज 0 देन 2 - 1 विल बी 1 आई थिंक दिस इज़ ज़ीरो एंड दिस इज़ टू एंड देन दिस इज़ अगेन ज़ीरो एंड दिस इज थ्री
एंड दिस इज़ आल्सो ज़ीरो जो करंट नीड होगी एंड देन 5 - 2 सो दिस इज़ आई थिंक गोइंग टू बी थ्री दिस इज़ दिस रिमेंस फोर एंड
दिस रिमेंस वन ये इन प्रोसेस का करंट डिमांड है हम क्या-क्या लोकेट कर चुके हैं e टाइप का 1 1 1 3 ंड 2 5 टोटल मेरे पास 8
था तो कितना बचा है थ्री f का सिर्फ एक ही एलोकेट किया चार मेरे पास था टोटल यहां भी कितना बचा है थ्री एंड आई थिंक जी तो पूरा
सिक्स का सिक्स एलोकेट कर चुका हूं मेरे पास कितना बचा है जीरो अब कोई आपसे पूछेगा दिस इज द सिनेरियो दो-तीन वैल्यू हमसे
कैलकुलेट करा ली एग्जामिनर ने अब पूछेगा बताओ सिस्टम डेड लॉक में है सेफ है एनसेफ है क्या मतलब होता है समझाता हूं तो
ओबवियसली जब आप डिमांड पूरी करने की कोशिश करेंगे पहले किसको ढूंढेंगे पहले उसको ढूंढिए जिसकी डिमांड सबसे कम है या जिसकी
मैं मैनेज कर कर सकता हूं फॉर एग्जांपल मेरे को समझ आ रहा है आप ध्यान से देखो p नॉ की करंट नीड में मैनेज कर सकता हूं p1
की नहीं कर पाऊंगा क्योंकि उसको जी का दो रिसोर्स चाहिए मेरे पास नहीं है है ना p2 की भी मैं कर सकता हूं आई थिंक यस मैं कर
सकता हूं p2 की करंट नीट फिलहाल मैनेज कर लूंगा यस एंड p3 की भी नहीं कर पाऊंगा क्योंकि उसको जी का वन चाहिए f का फोर
चाहिए मेरे पास नहीं है तो कोई भी प्रोसेस उठा लो जिसका डिमांड हम सेटिस्फाई कर सकते हैं p नो का कर सकते हैं ना ठीक है मान
लेते p नॉ हमने एग्जीक्यूट कर दिया अब हुआ क्या आप समझिए यह रिसोर्स मैंने इसको एलोकेट कर दी जैसे ही एलोकेट की इसका
लोकेशन और बढ़ गया इसकी करंट नीट जीरो हो गई और रन करने में चला गया अब होगा क्या क्योंकि मैं आपको ये समझा पा रहा हूं कि
मैं इसे रन कर पा रहा हूं बहुत सारी मैट्रिक्स चेंज करने में समझ आगा तो क्या आप ये मानते हो कि मैंने इसको रन कर दिया
और रन जब ये होके एग्जीक्यूट होके कंप्लीट हो जाएगा टर्मिनेट हो जाएगा तो अपना करंट एलोकेशन भी मुझे वापस करेगा तो मेरे पास
जो कि है 330 यह जब मेरे को वापस मिल जाएगा 10 तो अब मेरे पास कितना हो गया मेरे पास हो गया
फोर मेरे पास हो गया ्र मेरे पास हो गया वन जैसे जैसे प्रोसेस एग्जीक्यूट होते जाएंगे बाहर जाते जाएंगे मेरी ताकत बढ़ती
जाएगी क्योंकि जैसे वो बाहर जाएंगे उनका करंट लोकेशन मुझे मिलता जाएगा यस और मैं कहीं मार्क कर लेता हूं मैंने पी नो को रन
कर लिया अब बताइए किसकिस को रन कर सकता हूं अभी भी मेरे ख्याल से इधर नहीं कर सकता इधर नहीं कर सकता एक ही ऑप्शन बचा प2
कर सकता हूं तो प नो के बाद मैं को रन करने जाता हूं जो मैंने आपको समझाया मैं प्रूफ कर पा रहा हूं कि मैं p न की डिमांड
सेटिस्फाई कर सकता हूं तो मैं मान रहा हूं कि मैंने उसे रन कर दिया और रन कर दिया तो उसका एलोकेशन वापस मैं ले लूंगा व्हिच इज
लाइक 103 अब जैसे ही मैंने उसका करंट एलोकेशन वापस लिया बताइए मेरे पास क्या आ गया मेरे
पास आ गया फोर मेरे पास आ गया थ्र और यह हो गया फाइव अब तो मेरे को लग रहा है कि मैं किसी को भी मैनेज कर सकता हूं नहीं
अभी भी p3 को नहीं कर पाऊंगा बट हां p1 को जरूर मैनेज कर सकते हैं तो अब देखिए जब p1 को मैनेज करने जाएंगे तो यह इसका करंट
लोकेशन है मैं इसको सेटिस्फाई कर सकता हूं जी हां करंट नीड को और ऐसा है तो उसका लोकेशन मुझे वापस मिलेगा व्हिच इज लाइक 1
1 एंड 2 अब यह सम करेंगे तो बोलिए क्या हो जाएगा नाउ दिस विल बिकम 6स एंड 4 एंड 6 646 पे फाइनली आखिरी भी डिमांड पूरी हो
जाएगी इसका लोकेशन मुझे वापस मिलेगा और वह क्या है वो है 200 तोब मेरे पास हो जाएगा कितना 8 4 एंड 6 और जैसे बिजनेसमैन
को अपना हिसाब मिलाता है जरा देखिए सिस्टम की मैक्स डिमांड जो जिससे गेम शुरू किया था वही वापस आया कि नहीं आ आ गया 8486
सुबह किताब में था शाम को हिसाब लेगाया वापस आया किस सीक्वेंस में मैंने रन कर दिया मैंने p नॉ p2 p1 और सबसे बाद में p3
एक सीक्वेंस निकाला जिसमें रन किया तो अब बैंकर्स एल्गोरिथम के हिसाब से पूरी एजीक्यू ये जो आपने रन किया यही बैंकर्स
एल्गोरिथम है इसमें घबराने की बात नहीं है तो बताइए क्या सिस्टम डेडलॉक में है कि नहीं जी नहीं मेरे पास सबूत है इसको बोलते
हैं सेफ सीक्वेंस मुझसे बोलो क्या बोलते हैं सेफ सीक्वेंस मेरे पास ये सीक्वेंस है जिस सीक्वेंस में रन करने पर मैं आपको नजर
दिखा के समझा पा रहा हूं कि मैं हर किसी की डिमांड सेटिस्फाई कर सकता हूं और सिस्टम डेडलॉक में नहीं जाएगा कम टू दिस
थिंग नाउ हम बोलते हैं सिस्टम दो आइडियाज हो सकते हैं एक होता है सेफ एक होता है अनसेफ अगर मैं सेफ सीक्वेंस मेरे पास है
तो मैं कहलाता हूं सेफ स्टेट में और अगर मैं सेफ स्टेट में हूं तो डेडलॉक लगने का 0 पर चांस है कुछ लोग को लगता है अवॉइडेंस
वीकर है इसलिए शायद कभी-कभी लग सकता है नहीं लग सकता अवॉइडेंस में भी नहीं लग सकता देखो ना 0 पर चांस है ऊपर हालांकि
अगर आप देखोगे अगर मुझे कोई सेफ सीक्वेंस ना मिलती फॉर एग्जांपल लास्ट केस में देखो अगर मुझे कोई सेफ सीक्वेंस ना मिलती इसका
मतलब यह है कि डेड लॉक लग गया नहीं मैं तो वर्स केस एनालाइज कर रहा हूं बट इसका मतलब ये जरूर है कि डेड लॉक लग सकता है तो
अनसेफ होने का ध्यान से देख लीजिए अनसेफ होने का यह मतलब नहीं है कि डेड लॉक लग गया अनसेफ होने का मतलब है दैट देयर इज अ
पॉसिबिलिटी ऑफ डेड लॉक है ना तो सेफ सीक्वेंस क्या होती है सेफ स्टेट क्या है अनसेफ स्टेट क्या है यह पूरी बात हमने
यहां पर ऑब्जर्व कर ली है यही जो पूरा आईडिया हमने देखा अब यहां देखिए उसको स्टैंडर्ड तरह से रिप्रेजेंट कर रहा हूं
एग्जाम में कोई आपसे पूछेगा अवेलेबल मैट्रिक्स जो करंट मेरे पास अवेलेबल है मैक्सिमम नीड या मैक्सिमम डिमांड जो
प्रोसेस बताता है क्या-क्या डटा स्ट्रक्चर चाहिए देन एलोकेशन कितना हम लोकेट कर चुके एंड देन अगेन नीड से एलोकेशन माइनस करेंगे
मैक्सिमम से एलोकेशन माइनस करेंगे तो आपको करंट नीड मिल जाएगा अब अगेन एल्गोरिथम रन कैसे करता है वही पूरा प्रोसेस जो हमने
ऑब्जर्व किया बस नाम थोड़े से बदल देते हैं यहां पे जो वर्क है अवेलेबल जो हमारी मैट्रिक्स हुआ करती थी ना उसका नाम इसने
वर्क रख दिया यह नीड है यह फिनिश है स्टार्टिंग में फिनिश के केस में हर किसी को हम फॉल्स फॉल्स फॉल्स करेंगे ट्रू करते
जाएंगे अब क्या करेंगे बताओ यह नीड है यह अवेलेबल है क्या करोगे आप देखोगे क्या कोई नीड ऐसा है क्या जो अवेलेबल से कम है जब
गेम स्टार्ट होगा क्या कोई नीड ऐसा है जो अवेलेबल पहली बात तो प्रोसेस अभी एग्जीक्यू हुई ना हो फॉल्स हो क्या कोई
नीड ऐसा है जो वर्क से कम है फॉर एग्जांपल मेरे को पहले ही नजर आ रहा है जी इसका जो नीड है वो वर्क से कम है अब वर्थ से कम
होगा तो क्या होगा बोलो फिर वही कहानी मैं मान लूंगा कि मैंने इसको एग्जीक्यूट कर दिया और इसका जो एलोकेटेड होगा वो मुझे
मिल जाएगा तो मेरा क्या हो जाएगा मेरा वर्क हो जाएगा वर्क प्लस एलोकेशन और ये जो भी प्रोसेस मैंने रन किया मान लीजिए p नॉ
रन किया तो वहां पर मैं लिख दूंगा ट्रू यस अच्छा ये ना यहां पर प्रोसेस होना चाहिए सो दिस इज लाइक p न p1 p2 लाइक दिस जो भी
प्रोसेस रन किया वहां ट्रू कर दूंगा तो पूरी प्रोसेस सेम है बस लाइक दिस एज अ एल्गोरिथम के थ्रू उसने लिख के बता दिया
तो आई थिंक बैंकर्स एल्गोरिथम या सेफ्टी एल्गोरिथम कोई लिखने के लिए बोल दे विद एग्जांपल तो एक दो कोई छोटा सा केस बना लो
मैंने तो फिर भी चार प्रोसेस का बनाया तीन प्रोसेस का केस बनाओ ये एल्गोरिथम दो बार लिख के देख लो स्टेप बाय स्टेप चार लाइन
है कोई बहुत महान बात नहीं है सॉल्व कर सकते हो यस अच्छा एक इसी के अंदर आईडिया है अवॉइडेंस के अंदर रिसोर्स एलोकेशन
ग्राफ अगर बैंकर्स के पूरे डाटा को एक ग्राफ में रिप्रेजेंट किया जाए तो क्या सेम इंफॉर्मेशन कन्वे की जा सकती है हां
हालांकि इतना पॉपुलर नहीं है बट आईडिया आपको पता होना चाहिए फॉर एग्जांपल देखिए यहां पर आपको समझ आ रहा है एक
रिसोर्स टाइप है r1 जिसके पास दो रिसोर्स है दो कॉपीज है यह बोलते हैं एलोकेशन एज जहां पर क्लियर कट नजर आ रहा है कि यह जो
रिसोर्स है पहले वाला यह p1 को फिलहाल एलोकेटेड है और यह जो रिसोर्स है दूसरा यह प नॉट को एलोकेटेड है अगर प्रोसेस से
रिसोर्स पच जाती है उसको बोलते हैं रिक्वेस्ट एज यह भी समझ आ रहा है कि एलोकेशन के बाद भी एक रिसोर्स ऑलरेडी
एलोकेटेड है p1 कह रहा है मेरे को एक रिसोर्स और चाहिए समथिंग लाइक दिस है ना तो अगर रिसोर्स से प्रोसेस की तरफ ज गया
दिस इज कॉल्ड एलोकेशन और प्रोसेस से रिसोर्स की तरफ एज गया दिस इज कॉल्ड रिक्वेस्ट एज है ना यह सिनेरियो एक सिस्टम
का स्नैपशॉट बता रहा अब आपको जज करना है कि सिस्टम डेड लॉक में है कि नहीं जैसे मेरे को नजर आ रहा है यह r3 ी का कॉपी भी
एलोकेटेड नहीं है तो यह जो रिक्वेस्ट है क्या इस रिक्वेस्ट को मैं लोकेट कर सकता हूं क्या हां कर सकता हूं और देखो अब प2
से कोई आउटगोइंग ए तो है नहीं तो p2 का मतलब रनिंग स्टेट में रनिंग स्टेट में तो p2 बाहर जाएगा ये दोनों रिसोर्स रिलीज हो
जाएंगी अब देखिए जैसे ही दोनों रिसोर्स रिलीज होंगी मेरे ख्याल से पी नॉ रनिंग में जा सकता है बिकॉज नाउ दैट विल बिकम एन
एलोकेशन और ये रिक्वेस्ट भी एलोकेशन हो सकता है जैसे ही p नो बाहर गया वो भी रिसोर्स रिलीज करेगा अब किसका पहले नंबर
लेंगे r1 को अ इसको p को रन कर सकता है बिकॉज़ यह रिलीज हुआ तो एक रिसोर्स यह वाला जो है यह तो ऑलरेडी डन है यह जैसे ही
रिलीज होगा p न का ये एलोकेशन बन जाएगा इधर तो p1 एग्जीक्यूट होगा और सबसे लास्ट में जब सभी खत्म हो गए तो p3 भी हो जाएगा
तो लाइक दिस स्टेप बाय स्टेप आप ऑब्जर्व करके देख सकते हो कि जो रिसोर्स एलोकेशन ग्राफ है इसका मतलब मैंने आपको समझा दिया
और इसको देख के भी पूछा जा सकता है या समझाया जा सकता है कि बताओ डेडलॉक सिस्टम में डेडलॉक अ सिस्टम डेडलॉक में है कि
नहीं है है ना दिस इज एन आईडिया अच्छा यहां पर एक छोटा सा पॉइंट है जैसे यहां देखिए यह जो रिसोर्स एलोकेशन ग्राफिक्स
में एक साइकिल आपको नजर आ रही है इफ यू सी दिस ना देर इज अ साइकल अच्छा नोट्स सब कुछ मैंने मेंशन किया है यू कैन नोट देम डाउन
बाय पॉजियर टेक अ स्क्रीनशॉट एग्जाम पॉइंट ऑफ व्यू से बाकी समझ आपको आ गया होगा तो यह देखिए एक साइकिल है बट मुझे बताओ क्या
फिलहाल सिस्टम डेड लॉक में है एक्चुअली नहीं क्योंकि p2 इज इन रनिंग स्टेट वह बाहर जाएगा p4 इज आल्सो इन रनिंग स्टेट और
जैसे ये दोनों बाहर जाएंगे यह जो p3 का रिक्वेस्ट है यह लोकेशन बन जाएगा और यह जो p1 का रिक्वेस्ट है यह भी एलोकेशन बन
जाएगा अब p1 और p3 भी बाहर चले जाएंगे तो कुछ लोग ऐसा पूछते हैं रिसोर्स एलोकेशन ग्राफ में अगर साइकिल होती है डज इट मीन
दैट देर इज अ डेड लॉक आंसर इज नो सो प्रेजेंस ऑफ अ साइकिल अगर वहां पे साइकिल मिलती है इसका मतलब डेड लॉक हो सकता बट हो
जरूरी नहीं है तो वी से इट इज नेसेसरी बट नॉट सफिशिएंट साइकिल नहीं होगी तो डेड लॉक हो होगा क्या साइकिल नहीं होगी तो डेड लॉक
नहीं होगा यह तो तय है बट अगर साइकिल है तो डेड लॉक हो जरूरी नहीं है तो इट इज़ नेसेसरी बट नॉट अ सफिशिएंट कंडीशन तो हो
सकता है डेडलॉक हो हालांकि इसमें एक एक्सेप्शन है एक्सेप्शन क्या है अगर आपके पास रिसोर्स सिर्फ एक टाइप का है है ना
जैसे मैंने देखिए दोनों पॉइंट लिखे हैं साइकिल इंड रिसोर्स एलोकेशन ग्राफ इज़ नेसेसरी बट नॉट सफिशिएंट कंडीशन बट इफ
एवरी रिसोर्स हैव ओनली वन रिसोर्स टाइप यानी कि जैसे यहां पर ना r1 के पास दो रिसोर्स है अगर सिर्फ एक हो तो हर रिसोर्स
के पास अगर एक-एक कॉपी हो उस केस में द प्रेजेंस ऑफ अ साइकिल इज नेसेसरी एज वेल एज सफिशिएंट कंडीशन वैसे आई डोंट थिंक
सेमेस्टर एग्जाम में जरूरत है इस बात की लेकिन एक बेसिक आईडिया आपको समझ आना चाहिए तो आई थिंक ना अवॉइडेंस का पूरा अप्रोच
आपको समझ आया अब नेक्स्ट अप्रोच हमारा क्या है डिटेक्शन एंड रिकवरी अब ये क्या है ये थोड़ा सा और लेजी अप्रोच है
प्रॉब्लम क्या है अवॉइडेंस में भी रन टाइम पे बार-बार यह पूरा एल्गोरिथम आपको चलाक देखना पड़ेगा इसका अपना खर्चा है सारी
बुक्स मैनेज करनी पड़ती है उसकी कॉस्टिंग है तो एक सॉल्यूशन क्या हो सकता है ना अपन बुक्स मेंटेन कर रहे हैं कोई दिक्कत नहीं
किसके पास क्या कहानी बट चेक नहीं कर रहे जो जितना मांग रहा है देते जाते हैं रन टाइम प अगर बाद में कहीं प्रॉब्लम आती है
देन वी कैन रन दैट एल्गोरिथम टू फिगर इट आउट कि डेड लॉक लग गया क्या हर डिसीजन पे किसी ने कितना रिसोर्स मांगा एलोकेट कर दो
कोई दिक्कत नहीं बस बुक्स में मैनेज करते चलो ऐसा अप्रोच यूज करते हैं कहता है डिटेक्शन तो अगर डिटेक्शन हुआ पहली बात तो
मैं रन टाइम प मैनेज नहीं कर रहा मेरा काम आसान हो गया किताब है मेरे पास बट मैं एक एक वैल्यू एलोकेट करने से पहले चेक नहीं
कर रहा मैं बैंकर में सेफ्टी एल्गोरिथम या मैं बैंकर्स एल्गोरिदम रन नहीं कर रहा रन कब करूंगा जब प्रॉब्लम होगा अब अगर
डिटेक्ट कर लिया तो क्या करूंगा दो अप्रोचेबिलिटी बहुत ज्यादा बहुत नुकसान होगा एक तरीका हो
सकता है प्रोसेस को एक-एक करके किल करो एक प्रोसेस किल किया फिर एक और तब तक करते जाओ जब तक डेड लॉक हट ना जाए है ना यह
आईडिया है कंसंट्रेट करता है प्रोसेस प रिलेटिवली थोड़ा आसान है बट थोड़ा इनएफिशिएंट होगा क्योंकि लॉस ज्यादा होगा
एक हो सकता है कि यार डेड लॉक एक्चुअली सोचेंगे तो प्रोसेस की वजह से नहीं है रिसोर्स की वजह से है तो क्यों ना एक काम
करें कोई विक्टिम सेलेक्ट करो उसका रोल बैक करो रोल बैक मतलब होता है ना चेक पॉइंट्स होते हैं डेड लॉग डीबीएमएस में हम
पढ़ते हैं थोड़ा रोल बैक करोगे तो इन बिटवीन टाइम में इसने जितने रिसोर्स एक्वायर किए होंगे वो रिलीज हो जाएंगे फिर
थोड़ा और रोल बैक करो फिर थोड़ा और रोल बैक करो कंप्लीट या पार्शल रोलबैक करते जाओ जब तक वो रिसोर्स रिलीज ना हो जाए
जिनकी वजह से डेड लॉक लगा है अगर एक प्रोसेस को कंप्लीट रोलबैक करने के बाद भी रिसोर्स रिलीज नहीं हो पा रहे सफिशिएंट तो
एक और करो फिर एक और करो तो टू आइडियाज आइ दर यू किल प्रोसेस और यू प्रिवेंट और यू प्रीम रिसोर्सेस दो अप्रोचेबल रिजॉल्व
कराया जा सकता है दोनों के अपने फायदे अपने नुकसान होंगे दोनों ही अप्रोच में यह देखना थोड़ा साय यनो इंपॉर्टेंट है कि
किसको प्रिंट करना है या किसको किल करना है विक्टिम क्योंकि कोई अच्छा प्रोसेस आप किल करेंगे तो वर्क लॉस ज्यादा होगा बट
अगेन आई डोंट थिंक इसमें बहुत ज्यादा इन्वेस्टिगेट करने की जरूरत है आ इतना आया तो बैंकर्स के बाद आप इतनी बात समझा देंगे
तो दैट इज मोर देन सफिशिएंट नाउ कमिंग टू द लास्ट आइडिया व्हिच इज लाइक ऑस्ट्रिच अप्रोच या इग्नोर हैंस अब ये क्या कह रहा
है हां तो ऑस्ट्रिच की एक स्टोरी होती है आई थिंक वैसे रियलिटी में ऐसा नहीं है बट आईडिया क्या है कि जब कोई ऑस्ट्रिच को
पकड़ने के लिए आता ऑस्ट्रिच को लगता है कि भाई ऑस्ट्रिच मतलब शुतुरमुर्ग है ना लगता है कि अब कोई सॉल्यूशन नहीं है मैं कुछ कर
नहीं पाऊंगा तो वो क्या करता है वो अपना सर रेत में धंसा लेता है आंख बंद कर लेता है अब ऐसा करने से ऑस्ट्रिच को क्या लगेगा
कि जैसे मानो शिकारी चला गया लेकिन शिकारी गया नहीं वो आके उसको पकड़ लेगा बट बाद में आप बैठ के सोचेंगे ऑस्ट्रिच के पास
ऑप्शन क्या था जाना तो उसे था ही था पकड़ा तो वो गया था अब कम से कम तसल्ली से पकड़ा गया है है ना तो यहां पर एक आईडिया ये है
जिसको हम बोलते हैं इग्नोर हैंस कभी-कभी हम ये समझते कि डेडलॉक इतना सीवियर प्रॉब्लम होता भी नहीं है जितना हम
थोरेट्स हो सकते हैं रियल टाइम ऑपरेटिंग सिस्टम है एयर ट्रैफिक कंट्रोलिंग है जहां जान माल का बहुत खतरा है वहां मैं मान
सकता हूं कि डेड लॉक नहीं लगना चाहिए बट किसी के पर्सनल कंप्यूटर में अगर डेड लॉक लग भी गया तो क्या बड़ी बात हो गई स्विच
ऑफ करके स्विच ऑन कर लेंगे मैनुअल रिकवरी कर लेंगे इजेंट इट कॉस्ट क्या है डेडलॉक हैंडलिंग के लिए जो मॉड्यूल लिखना पड़ेगा
वो मॉड्यूल काफी हैवी है जो ऑपरेटिंग सिस्टम में मेन मेमोरी में जगह लेगा दूसरा बार-बार वो रन करेगा सिस्टम को स्लो करेगा
तो आईडिया ये है क्या ये प्रॉब्लम इतनी वर्थ इड भी है जिसको सॉल्व किया जाए सो मोस्ट ऑफ द ऑपरेटिंग सिस्टम जब पर्सनल
कंप्यूटर्स की बात कर रहे हैं चाहे वो मैक है चाहे यू नो प मैनेज किया जाए उससे सिस्टम और स्लो हो
जाएगा दिस इज एन आईडिया लेकिन मैं बोल रहा हूं एक्सेप्शन क्या है रियल टाइम सिस्टम्स है या कुछ सिस्टम इतने इंपॉर्टेंट है जहां
पर हम चाहते हैं देर इज अ 0 पर देर शुड बी 0 पर चांस ऑफ हैविंग अ डेड लॉक तो वहां पर जो दो अप्रोच हमने पढ़ी आइर यू कैन गो फॉर
तीन अप्रोच बल्की आप प्रिवेंशन अवॉइडेंस या डिटेक्शन रिकवरी तीनों में जा सकते हैं बट इग्नोर हैंस भी एक ऑप्शन है और रियल
लाइफ में भी मैं थोड़ा सा पॉइंट ऐड कर देता हूं इससे सीखने को मिलता है एवरी प्रॉब्लम डू नॉट डिव र्व टू बी सॉल्वड अगर
प्रॉब्लम ट्रिविया है तो उसको सॉल्व मत करिए पहले उसको सॉल्व करिए जो ज्यादा इंपॉर्टेंट प्रॉब्लम है तो बेटर काम कर
पाएंगे नाउ विद दिस डिस्कशन आई थिंक दे इज द एंड ऑफ प्रोसेस मैनेजमेंट 50 पर से ज्यादा काम हमने कंप्लीट कर लिया आई थिंक
60 टू 65 पर नाउ वि विल बी आई डिस्कसिंग द आई अच्छा फॉर कमांड रहता है फॉर कमांड थोड़ा सा प्रोसेस मैनेजमेंट का ही हिस्सा
है एंड देन वी विल गो एंड वी विल डिस्कस मेमोरी मैनेजमेंट इन डिटेल तो प्रोसेस मैनेजमेंट के लास्ट में जल्दी से एक बार
बात करते हैं फॉर कमांड और थ्रेडिंग की बहुत इंपॉर्टेंट कांसेप्ट है और कहीं ना कहीं आपको यहां से क्वेश्चन देखने को
मिलता है और जहां तक मुझे समझ आता है बच्चे कई बार डेफिनेशन रट लेते हैं बट क्लियर अंडरस्टैंडिंग नहीं समझ आ रही होती
तो छोटा सा बहुत कम टाइम लूंगा लेकिन पूरा लॉजिक क्लियर होगा जो भी क्वेश्चन आएगा सॉल्व करके आएंगे आप आईडिया समझिए क्या है
रिक्वायरमेंट के हिसाब से समझाता हूं पहले बात करते हैं फॉक कमांड की इन नंबर ऑफ एप्लीकेशंस स्पेशली दोज वेर वर्क इज ऑफ
रिपीटेड नेचर लाइक वेब ब्राउजर विद एवरी क्लाइंट वी हैव टू रन सिमिलर कोड एंड हैव टू क्रिएट अ सेपरेट प्रोसेस एवरी टाइम फॉर
सर्विंग ए न्यू रिक्वेस्ट एग्जांपल कोट कर रहे हैं मान लीजिए कोई बैंकिंग सर्वर है हम जो भी जाके यू नो लिखेगा
www.sbi.in मान लीजिए यू नो बैंकिंग पोर्टल पर्सनल बैंकिंग के लिए ओपन हो जाएगा एक ही कोड है हर यूजर के लिए सेम
प्रोसेस जनरेट होना है आप उसमें अपना लॉगिन आईडी अपना पासवर्ड डालेंगे ओटीपी आएगा ओटीपी एंटर करेंगे कैप्चा एंटर
करेंगे हो जाएगा लेकिन आप ऑपरेटिंग सिस्टम के बिहाव से सोचिए एक ही कोड है हर बार वही कोड रन होना है एक सेपरेट प्रोसेस जन
रेट होगी और ऑपरेटिंग सिस्टम का जो लोड है मान लीजिए अगर एक टाइम प 10000 20000 या 1 लाख लोग एसबीआई का नेट बैंकिंग ऐप यूज कर
रहे हैं तो सेपरेट सेपरेट प्रोसेस क्रिएट होती जाएगी जिससे कहीं ना कहीं ऑपरेटिंग सिस्टम का लोड बढ़ता है हर बार सेम काम हर
बार सेम काम करना पड़ रहा है नाउ क्या एक बेटर सॉल्यूशन नहीं है कि अगर हमारे पास कोई ऐसा शॉर्टकट कमांड हो जैसे एक प्रोसेस
हमारा चल रहा है हम एक सिंगल फंक्शन कॉल करें एक सिंगल कमांड कॉल करें और उस प्रोसेस का एकदम झट से पूरा कॉपी जनरेट हो
जाए ऑपरेटिंग सिस्टम को स्टेप बाय स्टेप फैशन में पूरा का पूरा प्रोसेस एकदम फिर से जनरेट ना करना पड़े आईडिया सूटेबल है
और उसी शॉर्टकट कमांड का नाम है फॉक कमांड तो क्या लिखता हूं इट इट मस्ट बी अ बेटर सॉल्यूशन देन इंस्टेड ऑफ क्रिएटिंग अ न्यू
प्रोसेस एवरी टाइम फ्रॉम स्क्रैच स्टेप बाय स्टेप ऐसा नहीं बटन दबाया प्रोसेस बन गया बहुत सारी चीजें उसमें होती है तो वो
सारा काम एक साथ ना करते हुए कोई एक ऐसा शॉर्टकट कमांड हमारे पास हो यूजिंग व्हिच हम पूरा का पूरा प्रोसेस फिर से क्रिएट कर
ले एग्जांपल देखिए फॉर कमांड काम कैसे करता है ये हमने प्रोसेस मैनेजमेंट में बात की थी एक प्रोसेस है जिसमें कोड है
स्टैटिक डाटा है स्टैक जो हमारा एक्टिवेशन रिकॉर्डर हीट जो हमारा डायनेमिक मेमोरी एलोकेशन है ये पूरा एक इमेज है अब फॉक
कमांड क्या करेगा जैसे ही आप फॉक कॉल करते हो इस पूरे के पूरे इमेज को उठा के बिल्कुल एक रिप्लिकेट करके एक नया कॉपी
बना देगा हालांकि एकदम सेम कॉपी नहीं बनाना था क्यों मान लीजिए कोई यूजर है उसका नेट बैंकिंग ऐप चल रहा है आप सेम
कॉपी बनाएंगे तो सारी डिटेल कॉपी हो जाएगी वो नहीं करनी थी बट कोई बात नहीं प्रोग्रामर लेवल पे जाके कुछ डिटेल्स में
चेंज कर सकता हूं बट होगा ये मेमोरी में लेट मी से नाउ दिस बिकम पैरेंट एंड दिस बिकम चाइल्ड एक बिल्कुल सेम कॉपी फॉक
कमांड जनरेट कर लेगा चेंजेज बहुत मैन्यूट होते हैं बिकॉज ज्यादातर टेक्स्ट तो सेम ही होता है वो चेंजेज हम बाद में जाके अलग
से मैनेज कर लेंगे तो देखिए यहां क्या लिखता हूं यर फॉक कमांड इज अ सिस्टम कमांड अभी अभी ओस की ही कमांड है यूजिंग व्हिच द
एंटायस ऑफ अ प्रोसेस कैन बी कॉपीडब्ल्यूबी फ टू कंप्लीट द क्रिएशन ऑफ अ न्यू प्रोसेस विथ स्पीड अब यहां पर सबसे बड़ा एडवांटेज
ऑपरेटिंग सिस्टम को क्या मिल रहा है उसको ये सारा काम स्टेप बाय स्टेप तरीके से नहीं करना पड़ रहा अच्छा एक प्रॉब्लम में
क्या बता रहा हूं एकदम सेम कॉपी जनरेट हो जाएगी जो कि शायद हमें नहीं करनी थी आफ्टर क्रिएटिंग अ प्रोसेस वी मस्ट हैव अ
मैकेनिज्म टू आइडेंटिफिकेशन पहचान है कि हम किसके बारे में बात कर रहे हैं चाइल्ड प्रोसेस के वन
रिटर्न कर रहा है तो पैरेंट प्रोसेस के बारे में बात कर रहे हैं तो अगर जीरो रिटर्न हुआ तो जो भी चाइड प्रोसेस है आप
उसमें जाके एप्रोप्राइटिंग फार्मूला अगर कोई आपसे पूछ ले तो काम करता
है 2 की पावर n - 1 तो अगर आप फॉर एग्जांपल फोर नंबर ऑफ टाइम्स फोर कमांड यूज करेंगे तो कितने कॉपी जनरेट होंगे 2
रेट पावर 4 -1 16 -1 15 चाइल्ड प्रोसेस क्रिएट होंगे एडवांटेज जो भी हमने समझा वही यहां पर एडवांटेज ए यू कैन सी इट इज
रिलेटिवली इजी टू क्रिएट एंड मैनेज सिमिलर टाइप ऑफ प्रोसेस ऑफ रिपिटेटिव नेचर विद द हेल्प ऑफ अ फॉर कमांड डिसएडवांटेज क्या है
डिसएडवांटेज बोलते हैं फरदर स्कोप ऑफ इंप्रूवमेंट देखो यह तो मानना पड़ेगा कि फॉर कमांड के थ्रू यह सारा काम करना कुछ
हद तक तो आसान हो गया है वरना हर बार ऑपरेटिंग सिस्टम को एकदम स्क्रैच से काम करना पड़ता था इसमें कोई डाउट नहीं है मैं
मानता हूं बट स्टिल क्या क्योंकि ये सिस्टम कमांड है कर्नल मोड यूजर मोड वाला बात याद है तो कंट्रोल पहले ओस के हाथ में
जाता है वो फॉर कमांड एग्जीक्यूट करता है तब जाके प्रोसेस जनरेट होती है दूसरा भले ही स्पीड से हुई बट प्रोसेस तो जनरेट हुई
सिस्टम में जितनी प्रोसेस होंगी उन सबका पीसी भी होगा उन सबका मेमोरी रिक्वायरमेंट होगा रिसोर्स रिक्वायरमेंट होगा वो सब भी
उसको हैंडल करना पड़ रहा है तो जो ऑपरेटिंग सिस्टम का बर्डन है वो मानते हैं कि थोड़ा कम जरूर हुआ है और ऑपरेटिंग
सिस्टम का बर्डन कंप्लीट नहीं हुआ है इसको अगर और अच्छे से स्पीड से सॉल्व करना है उसका सलूशन है थ्रेड तोब आपको स्टोरी
कनेक्ट करनी है कुछ लोग रिलेट नहीं कर पाते फर्क और थ्रेड दरअसल थ्रेड एक तरीके से फर्क प ही इंप्रूवमेंट है और
स्टार्टिंग में थ्रेडिंग का कांसेप्ट नहीं था धीरे धीरे हमने समय के साथ समझा कांसेप्ट क्या है सुनिए ध्यान से देखिए
आपने सुना होगा थ्रेड इ लाइटवेट प्रोसेस य डेफिनेशन सबको याद है इसका एटली मतलब क्या वो सीखना है अब यहां पर य हमारे सिंगल
प्रोसेस है ये हमारा थ्रेड है ये सिंगल एक थ्रेड मतलब एक प्रोसेस है अब देखिए जब हमें सेम कोड हमारा सेम है बस हमें
मल्टीपल कॉपी जनरेट करनी है वही ब्राउजर वाला एग्जांपल हो नेट बैंकिंग वाला तो यहां पर जो हमारा डेटा सेक्शन है जो हमारी
फाइल्स है जो हमारा कोड है वो तो एकदम सेम है बस हमारा जो एक्टिवेशन रिकॉर्ड है जो हमारे रजिस्टर्स की वैल्यू है जो हमारा यू
नो स्टैक कंटेंट है वो डिफरेंट है तो हम क्या कर रहे हैं अब माइंड यू ध्यान से समझिए प्रोसेस एक ही है एक ही प्रोसेस के
अंदर हम इंटरनली तीन डिफरेंट थ्रेड्स या तीन डिफरेंट एग्जीक्यूशन या एक्टिवेशन रिकॉर्ड मेंटेन कर रहे हैं और अब आज के
बाद हम इनको प्रोसेस कह के नहीं हम इनको थ्रेड कह के बुलाएंगे मान लीजिए प्रोसेस का नाम है p1 तो उसका नाम हो जाएगा थ्रेड
t11 थ t12 313 दैट इज व्हाई वी कॉल इट अ लाइट वेट प्रोसेस वई क्या इन सबके पास अपना पीसीबी है नहीं प्रोसेस ये एक ही है
इसके पास एक ही पीसीबी है सोचिए इस बात को क्या इन सबके पास अपना कोड अपना डाटा अपना फाइल है नहीं वो सब कॉमन है मुझे सेम चीज
की चार बार कॉपी जनरेट भी नहीं करनी पड़ी बड़ा एडवांटेज है यार लेकिन हां एक्टिवेशन रिकॉर्ड सबका अलग-अलग है अब अगर मैं आपको
दो मिनट बोलूं और सोचूं ध्यान से सोचिए एडवांटेज क्या है आपने जब एक नया थ्रेड बनाया क्या ओस को परेशान किया नहीं क्या
ओस को पता भी लगा नहीं क्या आपने कोई सिस्टम कॉल किया क्या यू नो कंप्यूटर जो है वो यूजर मोड से कर्नल मोड में ज्ञा
नहीं ये सब आप अपने लेवल पे मैनेज कर रहे हो ऑपरेटिंग सिस्टम के पास एक ही प्रोसेस और वो उसे ही हैंडल कर रहा है अगर मुझे एक
सेट से दूसरे सेट प जाना है तो क्या ये कांटेक्ट स्विच कहलाएगा नहीं क्योंकि वो इसके हिसाब से तो सेम ही प्रोसेस रन हो
रही है यह सारा मैनेजमेंट लोकली अपने लेवल पे हम कर रहे हैं तो अब आप सोचिए यहां पर सच में ऑपरेटिंग सिस्टम के लिए बड़ा रिलीफ
है बिकॉज एज अ प्रोसेस हर थ्रेड उससे बात नहीं कर रहा प्रोसेस अपने लेवल पे रिसोर्सेस मैनेज कर रहा और सारी हैंडलिंग
चल रही है ये आईडिया है थ्रेडिंग का तो थ्रेडिंग बेसिकली हमने क्यों लिया एक तरह से मल्टीपल प्रोसेस ही है लेकिन जो यू नो
जो लोड है ऑपरेटिंग सिस्टम का वो यहां पर बहुत कम हो जाता है तो देखिए मैं क्या लिखता हूं अ थ्रेड इज अ बेसिक यूनिट ऑफ
सीपीय यूटिलाइजेशन कंसिस्टिंग ऑफ प्रोग्राम कंप्यूटर ये सब हमारे पास है ट्रेडिशनल प्रोसेस को हम बोलते हैं हैवी
वेट बट यहां पर इंडिविजुअल थ्रेड्स को हम क्या बोलेंगे इट्स अ लाइट वेट बिकॉज इन सबके पास अपना पीसीबी नहीं है बाकी जो
कॉमन पार्ट है कॉमन है बाकी डिफरेंट पार्ट अलग है अब इसमें दो-तीन अंडरस्टैंडिंग है अंडरस्टैंडिंग क्या है दो शब्द आपने सुने
होंगे एक होता है यूजर लेवल थ्रेड एक होता है कर्नल लेवल थ्रेड पॉइंट समझिए जैसे मैं मैपिंग के हिसाब से समझाता हूं जो सबसे
सिंपल मैपिंग है दैट इ कॉल्ड मेनी टू वन मैपिंग इसका मतलब यूजर के हिसाब से बहुत सारे थ्रेड्स हैं ये सारे थ्रेड यूजर ने
अपने लेवल में बनाए हुए हैं बट जो हमने अभी समझा डिफॉल्ट कर्नल के हिसाब से आप देखेंगे सिर्फ एक ही थ्रेड है एक ही
प्रोसेस है तो क्या ये एडवांटेजेस है काफी हद तक कर्नल के लिए एडवांटेजेस है क्योंकि लोड बहुत कम है है ना कर्नल को बाकी चीजें
मैनेज नहीं कर रही जो प्रोसेस है वो अपने लेवल पे सारी चीजें मैनेज कर रहा है बट इसकी कुछ प्रॉब्लम भी है मान लीजिए
ऑपरेटिंग सिस्टम की जो मशीन है इट हैज मल्टी प्रोसेसिंग आर्किटेक्चर मेरे पास चार प्रोसेसर है लेकिन क्या मैं चार थ्रेड
चार प्रोसेसर पे रन कर पाऊंगा नहीं क्योंकि ओस को तो इसके बारे में पता ही नहीं है ओस को लग रहा है एक ही प्रोसेस है
तो बताओ कैसे रन करेगा अगर इसमें से थ्रेड नंबर टू जो है वो कोई इल्लीगल काम करते हुए पकड़ा गया ओस ने उसको ट्रैप कर लिया
यस उसे किल कर दिया बट ओ किसको ट्रैप करेगा ओ को तो पता ही नहीं मैं थ्रेड को ट्रैप कर रहा हूं ओ अनजाने में पूरी
प्रोसेस को ट्रफ कर लेगा जिससे बाकी थ्रेड भी परेशान हो जाएंगे कभी-कभी हो सकता है किसी इंडिविजुअल थ्रेड की रिसोर्स
रिक्वायरमेंट ज्यादा हो क्या वो यह बात अपने लेवल पे ऑपरेटिंग सिस्टम को कर्नल को बता पा रहा है नहीं क् कर्नल के हिसाब से
इंडिविजुअल प्रोसेस है और वो तो प्रोसेस को रिसोर्स एलोकेट कर रहा है अब ये प्रोसेस के ऊपर है कि वो इंटरनल इन
थ्रेड्स को कैसे मैनेज करें तो हम ये जरूर मान र है कि ऑपरेटिंग सिस्टम का लोड कम हुआ है लेकिन कुछ डिसएडवांटेजेस भी यहां
पर हमारे पास आ गए हैं अब इनको कैसे इंप्रूव किया जा सकता है एक बिल्कुल डिफरेंट आईडिया हो सकता है इंस्टेड ऑफ
मेनी टू वन हियर वी कैन हैव वन टू वन मॉडल इन वन टू वन मॉडल देखिए ऑब्जर्वेशन क्या है यहां पर बेसिकली आप देख रहे हो फॉर
एवरी यूजर लेवल थ्रेड वी हैव अ कर्नल लेवल थ्रेड और इन्हीं को बोलते हैं कर्नल लेवल थ्रेड आईडिया क्या है यहां पर कर्नल को
मान लेते कि इंडिविजुअल हर एक थ्रेड के बारे में पता है और हमारे 95 से लेकर विंडोज एक्स तक जितने वेरिएंट्स है सब यही
वाला वेरिएंट थे अब ऐसा करना क्या एडवांटेज है जैसे ही थ्रेड के बारे में कर्नल को पता लगा अब क्या मल्टी
प्रोसेसिंग मशीन में हर एक प्रोसेसर पे शेड्यूल कर सकता है हां इस बार क्या इंडिविजुअल थ्रेड को रिसोर्स एलोकेट कर
सकता है हां क्या इस बार ऑपरेटिंग सिस्टम पूरे प्रोसेस को ट्रैप करेगा या उसी थ्रेड को ट्रैप करेगा जो गड़बड़ कर रहा है सर
उसी को ट्रैप करेगा जो गड़बड़ कर रहा है तो जो एडवांटेजेस थे वापस आ जाते हैं लेकिन प्रॉब्लम क्या है फिर दोबारा कर्नल
का लोड बढ़ गया भई ये सारी व्यवस्था करी क्यों गई थी इसलिए तो करी गई थी कि ऑपरेटिंग सिस्टम को इंडिविजुअल लेवल पिन
थ्रेड्स को मैनेज ना करना पड़े बट ये चेंजेज हमने किए हमें काइंड ऑफ फिर से ये सारा काम करना पड़ रहा है तो अब तीसरा और
आखिरी तरीका हो सकता है बीच का रा लाइक मेनी टू वन जहां पर मेनी टू मेनी बहुत सारे यूजर लेवल है बहुत सारे करने लेवल है
डिपेंडिंग ऑन द रिक्वायरमेंट हम डिवाइड करते हैं उदाहरण के लिए मान लेते हैं ये दो प्रोसेस है इनके लिए एक सिंगल थ्रेड
हमने बनाया लेकिन ये इंपॉर्टेंट थ्रेड है इसके लिए एक कर्नल लेवल थ्रेड ये भी इंपॉर्टेंट यूजर लेवल थ्रेड है इसके लिए
भी एक कर्नल लेवल थ्रेड नाउ आर यू गेटिंग दिस आइ दिया अगर यह दो यूजर लेवल थ्रेड इतने इंपॉर्टेंट नहीं है इनका आपस में
इतना क्लैश नहीं है तो ओएस कोशिश करेगा इनको सिंगल लेवल में एक कर्नल थ्रेड में मैनेज करने की बट अगर ये अपने आप में इतने
कॉम्प्लेक्शन लेवल थ्रेड में मैनेज करना पॉसिबल नहीं है तब हम इनको इंडिविजुअल लेवल पे मैनेज कर सकते हैं तो फर्किंग और
थ्रेडिंग का पूरा आईडिया ये तीनों मॉडल्स एडवांटेज डिसएडवांटेज मेरे ख्याल से इतने लिमिटेड टाइम में लगभग लगभग सारी चीज
मैंने कवर कर ली है तो कोई भी यहां से बेसिक क्वेश्चन आता है आई थिंक यू आर इन द रेडी टू आंसर दैट क्वेश्चन नाउ फाइनली वीी
आर रेडी फॉर प्रोसेस मैनेजमेंट द सेकंड हाफ ऑफ द ऑपरेटिंग सिस्टम तो चलिए अभी बात स्टार्ट करते हैं मेमोरी मैनेजमेंट के
बारे में अब मेमोरी मैनेजमेंट में सबसे पहले आ जाती है मेमोरी हिरर की इसका क्या मतलब है देखिए ये पैरामेट टाइप स्ट्रक्चर
बड़ा इंपॉर्टेंट है एग्जाम पॉइंट ऑफ व्यू से इन जनरल अंडरस्टैंडिंग के लिए भी हमें समझना पड़ेगा कि कंप्यूटर में मेमोरी
इंपॉर्टेंट तो है बट कोई एक तरह की मेमोरी नहीं होती हमारे पास ऑप्टिकल डिस्क मैग्नेटिक डिस्क या जिसको हम सेकेंडरी
मेमोरी वर्चुअल मेमोरी कहते हैं वो है देन हमारे पास मेन मेमोरी है हमारे पास कैश है हमारे पास रजिस्टर्स है और ये तीनों
आइडियाज देखिए मैंने यहां प रिप्रेजेंट किए हैं जैसे जैसे इस पिरामिड में हम ऊपर से नीचे जाते हैं हमारी जो कैपेसिटी है
मेमोरी की वो बढ़ती है तो हार्ड डिस्क आमतौर पर 512gb या 1 टेराबाइट या 2 टेराबाइट हार्ड
डिस्क होती है ऊपर की तरफ जाएंगे तो मेन मेमोरी छोटा होगा कैश उससे भी छोटा होगा रजिस्टर्स तो बहुत ही कम होते है तो
कैपेसिटी ऊपर से नीचे जाते हुए बढ़ती है नीचे से ऊपर आते हुए कम होती है पर यूनिट कॉस्ट ये भी इंपॉर्टेंट है कितनी महंगी है
ओबवियसली डिजायरेबल बात है कि हमें चाहिए का मेमोरी सस्ती हो तो पर यूनिट कॉस्ट के हिसाब से देखेंगे तो जैसे जैसे अगेन यू गो
डाउन इन द पिरामिड तो हार्ड डिस्क रिलेटिवली पर यूनिट कॉस्ट के हिसाब से देखेंगे तो 1gb या 1 एब बहुत सस्ता होता
है जबकि कैश में मेन मेमोरी में रजिस्टर्स में तो बहुत ही महंगा होगा तो वहां भी समझ आता है कि नीचे की तरफ जाने में फायदा बट
अगेन सबसे इंपॉर्टेंट है टाइम हार्ड डिस्क या सेकेंडरी मेमोरी या मेन मेमोरी रिलेटिवली स्लो होते हैं रजिस्टर्स है कैश
है वो बहुत फास्ट होते हैं अब क्या करें दो क्राइटेरियास कह रहे हैं कि नीचे की तरफ जाए एक क्राइटेरिया कह रहा है कि ऊपर
जाओ बट वो अकेला इन दोनों पर भारी भी है क्योंकि बात टाइम की है तो क्या यूज करें हम रजिस्टर यूज करें या हम मैग्नेटिक यूज
करें कंक्लूजन होना चाहिए कि हमें दोनों यूज करना चाहिए यहां पे अच्छा और बुरे की बात नहीं है हर इन सभी टाइप की मेमोरी के
ना अपने फायदे भी और अपने नुकसान भी है लेट मी गिव यू एन एनालॉजी ये देखिए मैं मोड्स ऑफ ट्रांसपोर्टेशन की बात करर हू तो
देखिए तीन आइडियाज है हमारे पास साइकिल है कार है और एयर बस है एरोप्लेन है मैं आपसे पूछूं बताओ कौन सा अच्छा कौन सा खराब है
अजीब बात है ये बिकॉज घर के बहुत पास जाना है यू नो थोड़ा बहुत घूमना है तो साइकिल मेक्स सेंस अगर 100 200 किलोमीटर तक आपको
ट्रेवल करना है तो कार बहुत सेंसिबल हो सकती है वहां ना साइकिल काम आएगी नाना प्लेन कैम आएगा बट आपको यूएस जाना है दो
4000 ट्रेवल करना है दिल्ली से बम्बे जाना है तो मे भी एरोप्लेन सूटेबल है तो कौन सा अच्छा कौन सा खराब है सर तीनों यूज करने
चाहिए बस पॉइंट यह है कि आप किस समय किसको चूज कर रहे हैं सेम आईडिया मेमोरी पर एप्लीकेबल है अब मैं दूसरी एनालॉजी लगा
रहा हूं च इ वेरी इंटरेस्टिंग और पूरा पैटर्न जब आप ध्यान से देखेंगे ना तो आपको मजा आ जाएगा एनालॉजी के अंदर ध्यान से
देखिएगा पूरा कंप्यूटर कैसे काम करता है समझ आएगा यह आईडिया आपको कंप्यूटर आर्किटेक्चर में भी हेल्पफुल होगा और
ऑपरेटिंग सिस्टम में भी लॉजिक देखिएगा सीपी अरेंजमेंट कुछ इस तरह से है सीपीयू जो बटर जनरेट करेगा बल्कि पहले मैं
एक एनालॉजी करता हूं सपोज करिए देर यू सी देर इज अ कस्टमर जिसको कार खरीदनी है अब जब कस्टमर कार खरीदने जाता है तो कस्टमर
के पास कितने ऑप्शन होते हैं मेरे ख्याल से वो सारे के सारे ऑप्शंस है जो फैक्ट्री में बन रहे हैं कौन सा कलर कौन सा वेरिएंट
यू नो ट्रांसमिशन ऑटोमेटिक है या मैनुअल है फ्यूल कौन सा है सीएनजी है पेट्रोल है डीजल है और टॉप वेरिएंट है बेस वेरिएंट है
सारे के सारे परम्यूटेशन कॉमिनेशन आप बना लो तो बनेगी 100 200 तरह की गाड़ियां है ना एक ही कंपनी के अंदर ज्यादा भी बन सकती
है वो सब की सब यहां पर होती है लेकिन जो कस्टमर है क्या कस्टमर फैक्ट्री में जाता है मुझे बताओ नहीं कस्टमर जाता है शोरूम
में शोरूम में कंपनी कौन सी कार रखेगी ओबवियसली धीरे-धीरे काम करने कंपनी को समझ आ जाता है कि किस खास तरह के कौन से मॉडल
सबसे ज्यादा बिकते हैं या कौन से अलग-अलग वेरिएंट सबसे ज्यादा देखे जाते हैं वो आपको मिल जाएंगे शोरूम के अंदर बोलो हां
या ना अगर बन शोरूम में नहीं मिले तो जाहिर सी बात है शोरूम में हम बहुत सारी गाड़ियां रख भी नहीं सकते आमतौर पे शोरूम
से 510 किलोमीटर दूर जहां थोड़ी सस्ती जमीन मिलती है वहां पर एक गो डाउन होता है जहां पर 100 200 300 गाड़ियां होती है
कभी-कभी आप बोलते हैं नहीं मेरे को यही चीज चाहिए तो बोला जाता है सर एक घंटा रुकिए मंगा देते हैं या आप गो डाउन चले
जाइए और अगर आपको कोई ऐसा एक्सट्रीम वेरिएट चाहिए जो भी अवेलेबल ही नहीं है गाड़ी वेटिंग में है तो फिर आपसे ये नहीं
बोलेंगे कि आप 2000 किमी फैक्ट्री जाओ आपसे बोलेंगे आप वेट करो हम फैक्ट्री से गाड़ी गो डाउन में लाएंगे फिर जिस दिन
डिलीवरी होगी आपको शोरूम में लाकर डिलीवर करेंगे बिल्कुल जैसे ये कार कंपनी मैनेज करती है ना ऐसे ही हम मेमोरी मैनेज करते
हैं ऑपरेटिंग सिस्टम रियलिटी में जब एड्रेस जनरेट करता है सो सेकेंडरी मेमोरी लॉजिकल मेमोरी वर्चुअल मेमोरी ऑक्जिलियम
मैंने सारे नाम लिख दिए इसके लिए ही करता है यस लेकिन यहां तक अगर जाएंगे तो बहुत स्लो हो जाएगा टाइम बहुत ज्यादा लगेगा तो
हम क्या करते हैं इसमें जो डाटा इंपॉर्टेंट होता है वो डाटा पहले से मेन मेमोरी के अंदर रखते हैं यहां पे कैसे पता
लगता है यूज केस से पता लग जाता है इधर कैसे पता लगता है कि कौन इंपॉर्टेंट है इधर भी यूज केस ही लगता है आगे आपको
बताऊंगा लोकेलिटी ऑफ रेफरेंस जो डाटा लगातार इस्तेमाल हो रहा होता है हमें समझ आता है कि यार ये डाटा इस्तेमाल में इसको
यहां पे रख लेना चाहिए अगेन यहां पर क्या ऑपरेटिंग सिस्टम जा सकता है क्या सीपीयू मेन ममरी तक जा सकता है जा सकता है बट
अगेन इट इज नॉट एडवाइजेबल कि आप गो डाउन जाके कार लेके आओ इसमें भी जो डाटा ज्यादा इंपॉर्टेंट होता है जो अभी यूज हो रहा है
उसको उठा के कैश में रख लेते हैं जैसे गो डाउन की कुछ इंपोर्टेंट कार्ड उठा के शोरूम में रख लेते हैं तब होगा क्या स्टेप
नंबर वन में सीपीयू या ऑपरेटिंग सिस्टम जो भी बोल लीजिए जाता सबसे पहले ट्राई करता है कैश में सर्च करने का अगर कैश में डाटा
मिल गया तो बहुत बढ़िया है अगर नहीं मिला जो कि कुछ केस में होगा नहीं मिलेगा तो आप जाएंगे मेन मेमोरी के पास लेट मी से दैट
इज स्टेप नंबर टू अगर यहां डाटा मिलता है तो भी बढ़िया अगर यहां डाटा नहीं मिला तो अब हम सेकेंडरी के पास नहीं जाएंगे बहुत
स्लो होगा सिस्टम कुछ समय के लिए रुकेगा जो डाटा आपको को चाहिए उसको सेकेंडरी से फैच करेंगे फिर आप डेटा एक्सेस करेंगे और
फिर एग्जीक्यूशन कंटिन्यू करेंगे इस सारे प्रोसेस सीखेंगे भी उस डाटा को यहां प अगर जरूरत होगी तो कैश में भी कॉपी करके
रखेंगे क्योंकि पहली बार आपने मांगा था बट अगली बार मांगेंगे तो प्रॉब्लम ना हो सेम जिस फिलॉसफी ये करता है दैट इज हाउ द
एंटायस की वर्क्स एंड दैट इज हाउ इन द लंगर रन हमें जो टाइम है हमें जो स्पेस है हमें जो कॉस्ट एवरेज मिल रही होती है
क्योंकि 90 पर केस में आइजर मेन मेमोरी और कैश मेमोरी हिट यही डाटा मिल जाता तो एक्सेस टाइम भी फास्ट होता है लेकिन बड़ा
डाटा मैं यहां पर होल्ड कर पा रहा हूं तो मेरी जो कॉस्टिंग है वो भी कम हो जाती है है ना तो ये पूरा सिस्टम हेडरिक का है अगर
हम सारी चीजों को सही तरीके से इस्तेमाल करें रेशो के अंदर तो कंप्यूटर परफेक्ट काम कर रहा होता है अच्छा जो मैं आपसे
आईडिया बोल रहा था लोकैलिटी ऑफ रेफरेंस ये वही आईडिया है कि कंप्यूटर जब एग्जीक्यूट करता है तो डटा हम रैंडम कहीं से भी कुछ
भी नहीं मांग रहे होते सो आईडिया क्या है रेफरेंस टू मेमोरी एट गिवन इंटरवल ऑफ टाइम टेंड्स टू कन्फाइंड विद अ फ्यू लोकलाइज्ड
एरिया इन द मेमोरी दिस फिनोमिना इज नोन एज लोकैलिटी ऑफ रेफरेंस एग्जीक्यूशन के दौरान ऐसा नहीं है सेकेंडरी से कुछ भी मांग रहे
होते हैं अब मान लीजिए कोई प्रोसेस एग्जीक्यूट कर रही है तो आसपास का ही कुछ डाटा बार-बार काम आएगा इसी को फैच करके रख
लेते हैं जैसे कार के केस में मैंने आपको बताया कुछ गाड़ियां फैशन में होंगी जो ज्यादा बिक गगी कुछ कलर फैशन में होंगे जो
ज्यादा बिकेंगे सीख लेते हैं हम धीरे-धीरे क्या बिजनेसमैन को बताने की जरूरत है जो शोरूम चला रहा होता है कि कौन सी चीज बाहर
शोकेस में रखनी है उसको पता है कौन सी चीज ज्यादा बिकेगी उसको पता है किस चीज को पहले से ऑर्डर करके रखना है यही सारा गेम
है इसके भी दो वेरिएंट है स्पेशल लोकैलिटी और टेंपोरल लोकेलिटी द यूज़ ऑफ डेटा एलिमेंट इन द नियर बाय लोकेशन अगर मैं
यहां से डाटा मांग रहा हूं तो इस बात की इन जनरल पॉसिबिलिटी ज्यादा है कि इसके आसपास का डाटा भी मैं फ्यूचर में मांग
सकता हूं उसको पहले से लोड करके रख लो दैट इज कॉल्ड स्पेशियल लोकैलिटी टेंपोरल लोकैलिटी टेंपोरल लोकैलिटी रेफर्स टू द
यूज़ ऑफ स्पेसिफिक डाटा और रिसोर्स विद इन अ रिलेट मल ड्यूरेशन ऑफ टाइम अगर कोई डाटा भी इस्तेमाल हुआ है आगे बात करूंगा फिजिकल
लोकेशन छोड़ दो तो इस बात की उम्मीद है कि फ्यूचर में भी इस्तेमाल होगा क्योंकि अभी वो यूज़ केस में बचा हुआ है एल आरयू लीस्ट
रिसेंटली यूज एल्गोरिथम बाद में इसी फिलॉसफी के ऊपर काम करता है है ना तो मेमोरी यरार की लोकैलिटी ऑफ रेफरेंस ये सब
किस प्रिंसिपल पे किस तरह से काम करता है आई थिंक इसका एक बेसिक अंडरस्टैंडिंग आपका डेवलप हुआ होगा अब ऑपरेटिंग सिस्टम की
क्या-क्या ड्यूटीज है और वो कैसे परफॉर्म करेगा आगे देखते हैं सो नाउ वी नो व्हाट इज बेसिक अंडरस्टैंडिंग ऑफ मेमोरी रार की
एंड हाउ दैट वर्क्स अभी बात करता ऑपरेटिंग सिस्टम की क्या-क्या मेजर रिस्पांसिबिलिटीज है जो आगे मेमोरी
मैनेजमेंट में हम पढ़ेंगे सल को वन बाय वन पहला जो एक बड़ी इंपॉर्टेंट ड्यूटी है वो है एड्रेस ट्रांसलेशन तो देखिए सीपीयू जो
जनरेट करेगा वो हमेशा करेगा लॉजिकल एडस लॉजिकल एड्रेस फॉर सेकेंडरी मेमोरी जो हमने पढ़ा वच इज लास्ट जो फैक्ट्री है कार
बनाने वाली वो बट वो हमें पहले कहां सर्च करना है वो हमें पहले सर्च करना है मेन मेमोरी में उससे भी पहले सर्च करना ना है
कैश में तो मेन मेमोरी में जो एड्रेस काम करता है दैट इज कॉल्ड फिजिकल एड्रेस तो लॉजिकल एड्रेस को फिजिकल एड्रेस में
ट्रांसलेट करना आसान भाषा में बोलूं तो जो एड्रेस जनरेट हुआ है सेकेंडरी मेमोरी के लिए उसको कन्वर्ट करना ताकि हम मेन मेमोरी
में पहले सर्च करेंगे कर सके दैट इज कॉल्ड फिजिकल एड्रेस तो लॉजिकल टू फिजिकल कन्वर्जन करना इज द रिस्पांसिबिलिटी ऑफ
ऑपरेटिंग सिस्टम अच्छा एक बात यहां पर क्लियर कर दूं वैसे पूरी मेमोरी रार की हमारे पास है बट एज फार एज ऑपरेटिंग
सिस्टम इज कंसर्न वी डू नॉट स्टडी कैश हम कैश स्टडी नहीं करते यहां पर जो हमारा प्राइमरी कंसर्न है वो मेन और सेकेंडरी
मेमरी इनका जो रिलेशनशिप है वो है जब हम कंप्यूटर आर्किटेक्चर पढ़ेंगे उसकी भी एक वन शॉर्ट वीडियो आएगी तो वहां पर आप
देखेंगे मैं इन दोनों का रिलेशन यानी कि कैश का और मेन मेमोरी का रिलेशन आपस में स्टडी करूंगा तो वहां पे हम पहली दो
मेमोरी प कंसंट्रेट करते हैं ओ में हम लास्ट मेमोरी प कंसंट्रेट करते हैं यानी कि मेन प और सेकेंडरी प तो ये करना देन
एलोकेशन एंड डी एलोकेशन इतनी सारी प्रोसेस है जैसे हमने सीपीयू की बात की जैसे हमने रिसोर्सेस की बात की अ इतनी सारी प्रोसेस
होंगी कौन से प्रोसेस को कौन सा स्पेस देना है एलोकेट करना है डी एलोकेट करना है कितना देना है उसका हिसाब किताब रखना ये
सारी के सारी रिस्पांसिबिलिटी होगी ऑपरेटिंग सिस्टम की ये देखिए एलोकेशन डिएलोकेशन और साथ-साथ ट्रैकिंग वो बड़ी
इंपॉर्टेंट है ना वरना कैसे पता लगेगा कितना रिसोर्स एलोकेट कर चुके कितना हमारे पास है तो सारा काम इज द रिस्पांसिबिलिटी
ऑफ़ द ऑपरेटिंग सिस्टम एंड द लास्ट वन इज मेमोरी प्रोटेक्शन इस बात का भी साथ-साथ ध्यान रखना है कि कोई भी इल्लीगल एक्सेस
ना हो यानी के यू नो इट्स वेरी इंपोर्टेंट जो प्रोसेस आप प्रोसेस के पास जो मेमोरी स्पेस है जो उसकी लेजिटिमेसी
कर पाए एक प्रोसेस दूसरे प्रोसेस का या कोई प्रोसेस ऑपरेटिंग सिस्टम का कोड एक्सेस ना कर पाए तो इस चीज का भी ख्याल
कौन रखेगा ऑपरेटिंग सिस्टम रखेगा ये चार पांच मेजर रिस्पांसिबिलिटीज है अब बात करता हूं कि
अप्रोचेबल फिलहाल मेन मेमोरी का कर रहे हैं दो इंपॉर्टेंट आइडिया है जैसा आप देख पा रहे हैं कंटीन्यूअस और नॉन कंटीन्यूअस
इसको ऐसे भी समझिए विथ टाइम अगर हम देखें स्टार्टिंग में जब हमने काम करना शुरू किया था कंप्यूटर्स में मैं बात कर रहा
हूं 50 की 60 की 70 की इवन 80 की तो मोस्ट ऑफ द कंप्यूटर जो होते थे मेमोरी को वो हम कंटीन्यूअस फैशन में हैंडल करते थे
कंटीन्यूअस का मतलब क्या समझाऊं बेसिकली एक साथ लेकन एरे तो पूरी प्रोसेस एक साथ होगी प्रोसेस के टुकड़े नहीं करेंगे उसके
कुछ इश्यूज थे कुछ प्रॉब्लम्स थे जिस वजह से जैसे-जैसे कंप्यूटर कॉम्प्लेक्टेड मांड बढ़ती गई
हमने धीरे-धीरे कंटीन्यूअस से नॉन कंटीन्यूअस पे स्विच किया जहां पर जिसको आजकल हम बोलते हैं पेजिंग नाम आपने सुना
होगा या सेगमेंटेशन जहां पे नॉन कंटस फैशन में लाइक अ लिंक लिस्ट प्रोसेस के आप टुकड़े कर सकते हैं अलग-अलग टुकड़े
अलग-अलग जगह होल्ड कर सकते हैं तो ये दो आइडियाज है लेकिन आप जानते हैं हमारा सिलेबस इसी तरह से चलता है कि थोड़ा सा
हिस्टोरिकल पॉइंट ऑफ व्यू भी हम पढ़ते हैं ताकि हमें प्रॉब्लम समझ आए फिर उसका सॉल्यूशन समझ आए ताकि आजकल हम क्या काम कर
रहे हैं उसको आप अच्छे से रिलेट कर पाओ और फ्यूचर में उसमें इंप्रूवमेंट कर पाओ यस तो पहले अब हम डिस्कशन स्टार्ट करते हैं
कंटीन्यूअस एलोकेशन तो कंटीन्यूअस एलोकेशन के दो मायने हैं दोनों बातें बड़ी इंपॉर्टेंट है ध्यान दीजिए वी नो दैट
व्हेन अ प्रोसेस इ रिक्वायर्ड टू बी एग्जीक्यूटेड मस्ट बी लोडेड इन टू मेमोरी बाय द पॉलिसी इस इंप्लीमेंटेशन के दो
आइडियाज है पहला मस्ट बी लोडेड इन टू मेन मेमोरी कंप्लीट फॉर एग्जीक्यूशन देखिए ये तो आपको समझ आ गया कि क्या सीपीयू
डायरेक्ट सेकेंडरी को एक्सेस करता है नहीं करता जो चीज रन करनी हो उसको पहले कहां लोड करेंगे मेन मेमोरी में प्रोसेस को
पार्शियल लोड नहीं कर सकते उसका कुछ हिस्सा नहीं ला सकते कंटीन्यूअस एलोकेशन कहता है प्रोसेस को कंप्लीट लोड करना
पड़ेगा एंड दैट टू उसको भी एक साथ रखना पड़ेगा ऐसा नहीं मेन मेमोरी में भी आपने उसको टुकड़े-टुकड़े करके अलग-अलग कंटस है
ना भाई तो पूरा लोड करेंगे और एक साथ रखेंगे ये दो लॉजिक हमेशा काम करेंगे इसके बिना हम एडजस्ट नहीं करेंगे है ना ये बात
हुई कंटीन्यूअस की अब पहले कंटीन्यूअस को डिटेल में स्टडी करेंगे नॉन कंटीन्यूअस की बात नहीं करें
अब जैसे मैंने आपसे बोला दो प्रॉब्लम है एक है मेमोरी एलोकेशन और दूसरा एड्रेस ट्रांसलेशन तो एड्रेस ट्रांसलेशन सबसे
पहले देख लेते बड़ा इंपोर्टेंट डायग्राम है यूनिवर्सिटीज में सेमेस्टर्स में कई बार पूछा जाता है एड्रेस ट्रांसलेशन कैसे
होगा पूरा थ्योरी यहां पर मैंने लिख के रखा है पहले आईडिया आपको समझाता हूं देखिए कोई भी प्रोसेस हमारे पास है मैं मान
लीजिए दिस इज मेन मेमोरी एंड और इसके पीछे कहीं पे है सेकेंडरी मेमोरी और मान लीजिए सेकेंडरी मेमोरी का ये कोई एड्रेस है है
ना ये कोई प्रोसेस है जो एग्जीक्यूट करना है अब जैसे मैंने आपसे बताया कि जो भी प्रोसेस एग्जीक्यूट करना है क्या पहले
पूरी की पूरी प्रोसेस को लोड करना होगा मेन मेमोरी में जी हां तो मान लीजिए ये पूरी की पूरी प्रोसेस मेन मेमोरी में हमने
लोड कर ली तो इसमें अच्छी बात क्या है क्योंकि जब भी प्रोसेस लोड होगी कंपलीटली लोड होगी कंटीन्यूअस एलोकेशन जब भी
प्रोसेस लोड होगी एक साथ रखी जाएगी मेन मेमोरी के अंदर तो यहां पे चीजों को मैनेज करना बड़ा आसान होगा एड्रेस ट्रांसलेशन
फॉर एग्जांपल मान लेते हैं यहां पर है हमारी इंस्ट्रक्शन नंबर जीरो और यहां पर है इंस्ट्रक्शन नंबर 99 है ना तो सीपी जो
एड्रेस जनरेट करेगा वो 0 से 99 तक करेगा तो सबसे पहले मैं क्या करूंगा फॉर द प्रोटेक्शन मैं यहां पर लिमिट सेट करके
रखूंगा फॉर एग्जांपल मेरा जो लिमिट है टोटल रो से 99 तक कितना हुआ 100 हुआ ना मेरा लिमिट 100 है सो दैट जब भी लॉजिकल
लेटर जनरेट हो अगर मान लीजिए सीबी बोले मेरे को तो 115 चाहिए क्या 115 100 से कम है नहीं 100 से कम तो नहीं है इसका मतलब
इल्लीगल एक्सेस करना चाह रहा है कोई दूसरी लोकेशन एक्सेस करना चाह रहा है जो कंट्रोल में नहीं है अगर यह फेल हुआ इसको यहीं पर
ट्रैप कर लेंगे है ना मान लेते हैं कि फिलहाल ट्रैप वाली बात नहीं है इसने बोला मेरे को 15 चाहिए 15 इज लेस देन 100 तो हम
आगे मैपिंग अलाउ करेंगे अब देखेंगे रीलोकेशन वैल्यू हो सकता है यह जो प्रोसेस है जब हमने इसे मेन मेमोरी में रखा जो बेस
एड्रेस होता है ना लेट मी से मेन मेमोरी में इसका बेस एड्रेस है 1200 अब आपको क्या चाहिए 15 चाहिए अगर अगर रो 1200 पे है तो
क्या होगा इधर से मैं 1200 लूंगा ना दिस विल बिकम द वैल्यू ऑफ द रीलोकेशन रजिस्टर इधर से मिलेगा 15 एंड 1215 विल बिकम 1215
और ये जो आपके इंस्ट्रक्शन है वो इधर कहीं नजर आएगी और जाके आप एक्सेस कर लेे कितना सिंपल है अबे एरे की तरह हुआ ना जैसे एरे
का अगर मैं आपको बेस एड्रेस बताऊ और इंडेक्स बताऊं आप एक्सेस नहीं कर सकते कर सकते हैं बहुत आसान है उसी तरह ये है आपको
बस ये देखना है कि जो आपकी प्रोसेस है वो मेन मेमोरी में कहां पे रखी उसका बेस एड्रेस क्या है बेस एड्रेस विल बिकम द
लोकेशन रजिस्टर लॉजिकल एड्रेस विल टेल मी द इंडेक्स दोनों को मैं सम करूंगा मुझे एड्रेस मिलेगा जाके एक्सेस कर लूंगा तो
बिकॉज़ ऑफ दिस कंकर्स पॉलिसी एड्रेस ट्रांसलेशन बहुत सिंपल है बहुत आसान है बहुत फास्ट है स्ट्रेट फॉरवर्ड है हम
चीजों को सीधे से एक्सेस कर लेते हैं तो यह 110 पर हम मान के चलेंगे हमारा एडवांटेज हुआ अब बात हुई स्पेस एलोकेशन की
दो ड्यूटी थे ना एड्रेस ट्रांसलेशन स्पेस एलोकेशन अब बात करते स्पेस एलोकेशन स्पेस एलोकेशन कंटीन्यूअस स्पेस एलोकेशन अभी हम
पढ़ रहे हैं इसमें भी अंदर दो पॉलिसीज होती हैं एक पॉलिसी होती है वेरिएबल साइज पार्टीशनिंग एक पॉलिसी होती है फिक्स साइज
पार्टीशनिंग मैं एग्जांपल लॉजिक से आपको बताता हूं बड़ी मजेदार बात है व्हाट इज वेरिएबल साइज पार्टीशनिंग देखिए इसमें
हमारा अप्रोच ये है कि एक मेमोरी है मैं उसको एज अ सिंगल चंक एज अ सिंगल होल ट्रीट करूंगा मैं अपने से पहले से कोई पार्टीशन
नहीं कर रहा और जब जैसा डिमांड आता जाएगा एग्जैक्ट उतने पोशन काट के देता जाऊंगा फॉर एग्जांपल मेरे पास लेट मी से ये स्पेस
है टोटल 100 यूनिट्स का कोई प्रॉब्लम नहीं है किसी ने आ बोला प्रोसेस है सर 30 यूनिट चाहिए अब ये सभी खाली है तो मैंने 30
यूनिट्स लिया और उठा के एलोकेट कर दिया मैंने पूरा 100 नहीं किया 30 किया फिर से किसी ने आके बोलेगा मेरे को 15 चाहिए अभी
आगे मेरे को नजर आ रहा है ये 15 का एक दूसरा हिस्सा बनाया यह लोकेट कर दिया किसी ने आके बोला मेरे को 20 चाहिए अभी भी
स्पेस है एक 20 का हिस्सा एलोकेट कर दिया फिर हो सकता है 15 वाला कहीं चला जाए मतलब खाली हो जाए एमटी हो जाए फिर कुछ एलोकेट
करा कुछ समय के बाद इस तरह का सिनेरियो आपको यहां पे नजर आएगा जैसे ये एक स्पेस है इसको पहले हमने डिजाइन नहीं किया है ना
होता है ना हर शहर में इस तरह की जगह होती है कुछ पुराने इलाके होता है कोई वेल मैनेज्ड प्लान नहीं है जहां जिसका मन है
ऐसे बनाते जा रहा है दिस काइंड ऑफ मैनेजमेंट इज कॉल्ड वेरिएबल साइज पार्टीशनिंग जहां पे सिस्टम पहले से आपको
डिक्टेट नहीं करेगा आपकी मोरल पुलिसिंग नहीं करेगा अपने हिसाब से आप बनाते जाओ जो खाली है चला जाएगा और कुछ समय के बाद
हालांकि ऐसे ही मेमोरी लगी जैसे ये आपको घर नजर आ रहे है बात समझ आती है मैं पढ़ूं एक बार इन दिस पॉलिसी इन द स्टार्टिंग वी
ट्रीट द मेमोरी एज अ होल और अ सिंगल चंक व्हेन एवर प्रोसेस रिक्वेस्ट फॉर सम स्पेस एगजैक्टली द सेम स्पेस इज एलोकेटेड इफ
पॉसिबल द रिमेनिंग कैन बी यूज्ड अगेन बच्चे को दोबारा इस्तेमाल कर लेंगे सिंपल एक लॉजिक हो सकता है कि नहीं इसमें हम
थोड़ा सा दिमाग लगाएंगे हम इसे थोड़ा सा मैनेज करेंगे कैसे मैनेज करेंगे विद द आइडिया ऑफ फिक्स साइज पार्टीशनिंग सो हियर
मैं एक एग्जांपल ले रहा हूं रेस्टोरेंट का सोचो रेस्टोरेंट का एग्जांपल कैसे काम करता है कि आपने गए होंगे किसी रेस्टोरेंट
में खाना खाते फाइन डाइन जहां पर आप देखेंगे जो रेस्टोरेंट का मालिक है ये जो स्टाफ है जो मैनेजमेंट है उनको अंदाजा है
कि लगभग कितने क्लाइंट आते हैं किस तरह के आते हैं तो देयर शुड बी सम बिगर टेबल्स अगर कोई पूरी फैमिली आती है तो दे शुड बी
कंफर्टेबल दो लोग हैं चार लोग हैं छोटी टीम है वो है कुछ कपल्स अगर आते हैं उनके मैनेजमेंट का पूरी व्यवस्था होनी चाहिए तो
यहां पर उन्होंने अपने हिसाब से इसको पार्टीशन कर दिया जैसे कोई सोसाइटी बनाता है ू बीएच के थी बीएच के वन बीएच के फोर
बीएच के अलग-अलग साइज के प्लॉट्स पहले से काट के रखते हैं ना कोई आके बोले कि मेरे को कंटीन्यूअस यानी कंटीन्यूअस नहीं
मिलेगा हमने अपने हिसाब से पार्टीशन कर दिया है या आप सिस्टम में ड्राइव नहीं बना लेते सी ड्राइव डी ड्राइव ई ड्राइव दैट इज
कॉल्ड नथिंग बट द फिक्स साइज पार्टीशनिंग तो जहां पर हम अपनी अंडरस्टैंडिंग के हिसाब से
पहले से पार्टीशन बना के चीजों को मैनेज करें दिस इज कॉल्ड फिक्स साइज पार्टीशनिंग जहां पे हम यू नो छोड़ दे उस बात को
डिमांड और सप्लाई के हिसाब से चीजों को मैनेज होने दे दैट इज कॉल्ड वेरिएबल साइज पार्टीशनिंग इसमें ये बात आपको ध्यान रखनी
है अगर मान लीजिए किसी फैमिली के अंदर नाइन मेंबर्स है मैंने 10 लोग वाली टेबल दी अब ये खाली है यह किसी और को नहीं दे
सकते कि मैं पूरा ही पार्टीशन एलोकेट करूंगा मैं इसको डिवाइड नहीं कर सकता जो गया वो गया आठ है को सात फैमिली की सात
मेंबर की फैमिली आई तो मैं मैं ये एलोकेट कर दूंगा अ ये स्पेस खाली हो गया सर ये इसमें प्रॉब्लम है बचाएगा कुछ स्पेस आगे
बताऊंगा इसको किस नाम से बुलाते हैं लेकिन यहां पर जितनी डिमांड होगी उतना सप्लाई करूंगा इसमें प्रॉब्लम क्या है लॉन्ग रन
में इसे मैनेज कौन करेगा इसमें थोड़ा सा स्पेस वेस्ट होता है इन दोनों के अंदर ही स्पेस एलोकेशन के कुछ आइडियाज है जैसे
आपने सुना होगा फर्स्ट फिट बेस्ट फिट वर्स्ट फिट वो क्या आइडियाज है अब आइए पहले उनको स्टडी करते हैं ओके तो अब यहां
पे तीन पॉलिसी हमारे पास है एक है फर्स्ट फिट एक है बेस्ट फिट एक है वस्ट फिट सो आई विल गो वन बाय वन और दोनों जो हमारी
स्कीम्स है ना फिक्स साइज पार्टीशनिंग और वे वेरिएबल साइज पार्टीशनिंग दोनों स्कीम में तीनों पॉलिसी एप्लीकेबल है आई विल गो
वन बाय वन सो एज यू अंडरस्टैंड जैसे य एफसीएफएस हमने पढ़ा था सीपीय शेड्यूलिंग में हर जगह ये सबसे डिफॉल्ट प्रिंसिपल
होता है सो व्हाट इज फर्स्ट फिट पॉलिसी मेरी जो मेमोरी है है ना चाहे वो पार्टीशन में है या वो वेरिएबल पार्टीशनिंग स्कीम
में है मैं एक तरफ से फर्स्ट फिट पॉलिसी में हमेशा मैं स्टार्टिंग से सर्च करना स्टार्ट करूंगा और जो पहला अवेलेबल स्पेस
मुझे मिलेगा व्हिच इज सफिशिएंट इनफ उसको उठा के मैं एलोकेट कर दूंगा तो यहां पर मैं बहुत ज्यादा एफिशिएंसी पे ध्यान नहीं
दे रहा जो पहला स्पेस मुझे मिलेगा जो सफिशिएंट इनफर खाली है फॉर एग्जांपल मान लिया किसी ने मेरे को बोला कि यार मेरे को
ना 5kb ऑफ स्पेस चाहिए पहले दो सेल्स बिल्कुल फिल थे तीसरा सेल खाली था बट वो 4kb था तो इससे कुछ होगा नहीं उसके अगला
नंबर फॉर एग्जांपल 20kb है है ना तो अब मेरे को 5kb स्पेस चाहिए इधर 20 केब तो मैं ये नहीं देख रहा कि इसके आगे मैं
जाऊंगा तो लेट मी से 7kb है थोड़ा बेटर है थोड़ा छोटा ना जो पहला अवेलेबल स्पेस मिलेगा व्हिच इज सफिशिएंट इनफ टू
सेटिस्फाई वो मैं उठा के एलोकेट कर दूंगा सो दिस इज़ द फर्स्ट फिट पॉलिसी अब अगेन डिपेंडिंग ऑन वेरिएबल साइज और फिक्स्ड
साइज अगर ये वेरिएबल साइज पार्टीशनिंग है तो 20 में आप समझ रहे हैं मैं पांच ही यूज़ करूंगा और जो बचा हुआ 15 है वो रीयूज
हो जाएगा अगर ये फिक्स साइज पार्टीशनिंग है और 20 का ही एकमात्र ये मतलब पार्टीशन है तो 20 का 20 पूरा लेक्ट होगा जो बचा
हुआ स्पेस होगा वो वेस्ट हो जाएगा बट फिलहाल आपको इस आईडिया पे ध्यान रखना है व्हाट इज फर्स्ट फेट एक तरफ से सर्च करना
चालू करेंगे जो पहला अवेलेबल स्पेस मिलेगा उसको एलोकेट करेंगे एंड देन आगे बढ़ जाएंगे यस दैट इज फर्स्ट फट सिंपल है इजी
टू यूज़ है इजी टू अंडरस्टैंड है अगेन टाइम या स्पेस की टर्म्स में कुछ अच्छा नहीं होगा क्या देखो स्टार्टिंग में तो
आपको जल्दी-जल्दी मिलेगा लेकिन होगा क्या कुछ समता आसपास का सारा स्पेस आप खा चुके होंगे फिर आपको दूर जाना पड़ा करेगा
इनएफिशिएंट भी है कभी-कभी हो सकता है थोड़ा आगे जाएंगे तो थोड़ा छोटा स्पेस मिल जाए व्हिच इज़ एफिशिएंट इनफ बट आप बड़ा
स्पेस भी एलोकेट कर सकते हैं व्हिच इज़ अ काइंड ऑफ़ अ वेस्टेज मैं इस पे एक न्यूमेरिकल भी सॉल्व करेंगे अगला क्या
बेस्ट फट अब जो आप सोच रहे होंगे वही आईडिया यह क्या करता है यह ऐसा नहीं कि स्टार्टिंग में ही जो अवेलेबल मिला उसी को
एलोकेट करेगा सो बेस फिट पॉलिसी क्या करता है इट गोज एंड सर्च द एंटायस करेगा और वह स्पेस एलोकेट करेगा जो
स्मॉलेट इनफ हो फॉर एग्जांपल अगर मेरा डिमांड है मान लीजिए 5kb का यस मेरे पास कुछ स्पेस खाली है जिसमें कि मेरे पास
15kb है मेरे पास एगजैक्टली 5kb है मेरे पास 6 kb1 प मैच हो रहा तो सबसे अच्छा क्या होगा
नाउ दैट इज़ बेस्ट फिट पॉलिसी यस अगेन फिक्स साइज पार्टीशनिंग में तो शानदार है क्यों क्योंकि फिक्स साइज पार्टीशनिंग में
जो अवेलेबल स्पेस बचता है बाद में वो रीयूज होता है क्या वो तो होटल के टेबल की तरह है तो अगर मैं इधर कर दूंगा तो एक
स्पेस एक के भी वेस्ट ही हो जाएगा वो बेटर है वेरिएबल साइज पार्टीशनिंग में हालांकि लॉन्ग रन में हमें लगता है वो इतना अच्छा
अप्रोच नहीं है क्यों होता ये है बेस्ट फिट पॉलिसी की वजह से अगर वेरिएबल है तो हम छोटे से छोटा स्पेस एलोकेट करते हैं
उससे क्या होता है जो लेफ्ट ओवर स्पेस अब मान लीजिए 6 केब वाला स्पेस हम एलोकेट करते हैं फॉर एग्जांपल 5kb एलोकेट किया है
अभी जो 1kb की स्ट्रिप बची है किसके काम आनी है बताओ बहुत रेयर सिनेरियो है कि छोटी-छोटी स्ट्रिप्स बाद में किसी के काम
आए तो सोचिए बेस्ट फिट पॉलिसी दरअसल अगर वेरिएबल साइज पार्टीशनिंग है तो बचा हुआ स्कीम रीयूज हो जाता है लेकिन बेस्ट फिट
पॉलिसी में नहीं हो पाता कि वो छोटे-छोटे लेफ्ट ओवर स्पेस मिलते रीयूज नहीं होते तो ये पॉलिसी बेस्ट फिट पॉलिसी वेरिएबल साइज
पार्टीशनिंग में दरअसल वस्ट हो जाती है यस एंड गोइंग टू द लास्ट वन वर्स फिट अब आपको समझेगा अभी कि क्यों कोई वर्स फिट पॉलिसी
स्टडी करेगा तो वर्स फिट में क्या है आई एम गोइंग टू सर्च द एनटायर मेमोरी स्पेस और मैं क्या करूंगा मैं वो पार्टीशन में
वो चंक एलोकेट करूंगा जो स्मॉलेट होगा कि लार्जेस्ट होगा जो लार्जेस्ट होगा यस अब ये सच में वर्स्ट है अगर फिक्स साइज
पार्टीशनिंग है ये तो वही वाली बात हो गई कि मान लीजिए एक होटल में आप गए और जो टेबल थी आठ लोगों के टेबल पे एक बंदा जाके
बैठ गया तो बचा हुआ स्पेस पूरा वेस्ट हो गया अब कोई उस टेबल को यूज नहीं कर सकता या यहां पर बात करूं मेरे पास 100 केब का
एक पार्टीशन और मैं 10 केबी का प्रोसेस एलोकेट कर दूं पूरा का पूरा लेफ्ट ओवर स्पेस वेस्ट हो गया अगर फिक्स साइज
पार्टीशन है वेरिएबल साइज पार्टीशनिंग में बढ़िया है क्यों क्योंकि 10 गया लेकिन बचा हुआ जो 90 है वो लेफ्ट ओवर रियू जबल भी है
दूसरा वो इतना बड़ा है कि उसके रीयूज होने की जो पॉसिबिलिटी है जो संभावना है वो भी ज्यादा है तो यहां पे अच्छा काम करेगा यस
तो आई होप आपको समझ आया बेस्ट फिट वेरिएबल साइज पार्टी में अच्छा काम वेबल हा बेस्ट फिट वेरिएबल साइज पार्टीशनिंग जो होगी
वहां पर काम करेगा और जो वर्स फिट है वो वेरिएबल साइज पार्टीशन में वस फिट अच्छा काम करेगा बेस्ट फिट फिक्स साइज पार्टीशन
में अच्छा काम करेगा एक न्यूमेरिकल पहले से बना के रखा है एंड इमेजिन ट इ फिक्स साइज पार्टीशन ज्यादातर क्वेश्चन फिक्स
साइज पार्टीशन प आते हैं तीनों पॉलिसी यूज करेंगे हमारे पास फाइव पार्टीशन है 100 500 200 300 600 और कुछ रिक्वेस्ट
रिक्वेस्ट क्या है 112 417 112 एंड 426 पहली पॉलिसी मान लीजिए मानता हूं फस्ट फिड अब 212 सर्च करना स्टार्ट करूंगा मैं
इधर एलोकेट कर दूंगा बोला ना जो पहला स्पेस अवेलेबल है वो एलोकेट करेंगे अब ये जो लेफ्ट ओवर स्पेस है यूज होगा कि नहीं
होगा नहीं होगा क्योंकि फिक्स साइज पार्टीशन की बात कर रहा हूं आगे देखिए 417 सफिशिएंट नहीं है सफिशिएंट नहीं है
सफिशिएंट नहीं है 417 इधर जाएगा अगेन थोड़ा स्पेस वेस्ट होगा क्योंकि 600 का पूरा पार्टीशन अलर्ट किया है 112 इधर से
चलेंगे सफिशिएंट नहीं है इधर आएगा 112 और अगेन लगभग आधे आधा स्पेस यहां भी वेस्ट होगा और फाइनली 426 आप ध्यान से देखेंगे
तो आपको समझ आएगा इट विल रिमन पेंडिंग ये लोकेट हो ही नहीं पाएगा ये 300 बचा है ये दोनों साथ में नहीं है साथ में होता तो भी
मैने जबल नहीं था लेफ्ट ओवर स्पेस है बट सब अलग-अलग है तो फर्स्ट फिट पॉलिसी आप देख रहे हो कुछ अच्छा काम किया नहीं इसने
अब देखते हैं बेस्ट फिट कैसे काम करता है 212 फिक्स साइज में तो बेस्ट फिट अच्छा काम
करता है तो ढूंढिए 212 का सबसे छोटा स्पेस कौन है यह तो नहीं कर पाएगा 300 में जाएगा 212 और लेफ्ट ओवर स्पेस वेस्ट हो गया 417
सबसे छोटा स्पेस ये 417 इधर लोकेट करता हूं लेफ्ट ओवर स्पेस वेस्ट हो गया 112 सबसे छोटा ये 112 इधर गया लेफ्ट ओवर स्पेस
वेस्ट हो गया 426 थैंक गॉड इस बार देखिए कोई रिक्वेस्ट मेरी पेंडिंग नहीं रही सब में कुछ ना कुछ एलोकेट हो रहा है तो जब भी
फिक्स साइज पार्टीशन की बात करेंगे बेस्ट फिट सच में बेस्ट काम करेगा और बस्ट फिट देखिए क्या मत दिलाता 212 ढूंढिए सबसे
बड़ा स्पेस ये इधर आ गया 212 लेफ्ट ओवर स्पेस वेस्ट 417 सबसे बड़ा बस मेरे ख्याल से आगे हम कुछ कर नहीं
पाएंगे 417 काफी स्पेस वेस्ट हुआ 112 अच्छा नहीं हो पा रहा है 300 में चला जाएगा सो 112 है ना जी हां
112 लेफ्ट ओवर स्पेस वेस्ट एंड अगेन 426 विल रिमन पेंडिंग यूज नहीं हो पाएगा तो आई थिंक फर्स्ट फिट बेस्ट फिट वर्स्ट फिट का
तीनों का एक बेसिक अंडरस्टैंडिंग आपका डेवलप हुआ होगा एक और पॉलिसी भी कभी-कभी आप सुन सकते हो इ कॉल्ड नेक्स्ट फिट
पॉलिसी वो क्या है फर्स्ट फिट में ही थोड़ा सा मॉडिफिकेशन है मॉडिफिकेशन क्या है कि जो हमारा फर्स्ट फिट पॉलिसी है वो
क्या करता है हर बार स्टार्टिंग से सर्च करना शुरू करता है यहां पर हम क्या कहते हैं पहली रिक्वेस्ट जहां भी सेटिस्फाई की
है जब अगली रिक्वेस्ट एंटरटेन करेंगे तो वहीं से आगे बढ़ेगा स्टार्टिंग से मत चलिए बस इतना सा चेंज है तो नेक्स्ट फिट इज अ
मॉडिफाइड फर्स्ट फिट पॉलिसी वेयर आफ्टर सर्विसिंग द फर्स्ट रिक्वेस्ट जो अगली रिक्वेस्ट में सेटिस्फाई करूंगा मैं वहीं
से आगे बढूंगा ना कि स्टार्टिंग से यस तो ये एक आईडिया है जो यहां पर काम करता है अब मैं दो तीन इंपॉर्टेंट कंक्लूजन यहां
पे कर देता हूं एक्सटर्नल इंटरनल फ्रेगमेंटेशन क्या कहानी है देखिए जब भी हम फिक्स साइज पार्टीशनिंग करते हैं अपने
हिसाब से पार्टीशन बनाते हैं तो जरूरी नहीं है कि हमारा जो पार्टीशन ऑ सिस्टम की जो डिमांड थी दोनों आपस में हमेशा
एग्जैक्ट मैच करें एक मिसमैच होगा और उस मिसमैच की वजह से एक्सटर्नल फ्रेगमेंटेशन होगा जैसे यहां पर हम बात कर रहे हैं अब
फॉर एग्जांपल ये एक फैमिली है है ना ये सच में एक फैमिली है बिग सीजन फैमिली इनको एक पार्टी बर्थडे पार्टी सेलिब्रेट करनी है
दे वांट टू गो टू अ रेस्टोरेंट बट यहां पर आप देखो अगर आप टोटल काउंट करोगे जितने मेंबर इनके पास है और जितना स्पेस यहां पर
है क्या स्पेस अवेलेबल है स्पेस तो अवेलेबल है बट वो स्पेस कंटीन्यूअस नहीं है अल अ अलग अलग-अलग तरीके से हमने
पार्टीशन कर दिया बोलो हां या ना तो क्या आपको बर्थडे पार्टी इस तरह से सेलिब्रेट करना अच्छा लगेगा दैट एवरी बडी इ सिटिंग
ऑन डिफरेंट टेबल काइंड ऑफ नो दिस प्रॉब्लम इज नोन एज एक्सटर्नल फ्रेगमेंटेशन डेफिनेशन आपके सामने लिखी है फिर भी मैं
बताऊं तो जब हमें जितना स्पेस चाहिए वो स्पेस अवेलेबल है कोई प्रॉब्लम नहीं टोटल स्पेस अवेलेबल है बट हमें स्पेस
कंटीन्यूअस फैशन में चाहिए स्पेस कंटीन्यूअस नहीं है स्पेस फ्रेगमेंटेड है इसलिए रिक्वेस्ट एंटरटेन नहीं की जा सकती
दैट इज़ कॉल्ड एक्सटर्नल फ्रेगमेंटेशन मेरे पास एक मेमोरी है बीच में थोड़ा सा स्पेस ऑक्यूपाइड है
एक तरफ 5kb खाली है एक तरफ 4kb खाली है नोटिस करिए यस अब मैं इसको इस्तेमाल करना चाहते हूं एक प्रोसेस है जिसका डिमांड है
7kb का क्या 7kb अवेलेबल है 4 + 9 अवेलेबल तो बट एलोकेट कैसे करूं इधर पांच का टुकड़ा इधर चार का टुकड़ा ये काम नहीं
करेगा दिस इज़ आइडिया ऑफ़ एक्सटर्नल फ्रेगमेंटेशन बहुत इंपॉर्टेंट टर्म है यह नेक्स्ट इज इंटरनल फ्रेगमेंटेशन अब ये
क्या प्रॉब्लम है ये वो प्रॉब्लम है कि एक पार्टीशन है फिक्स साइज पार्टीशनिंग पॉलिसी है हमने पूरा स्पेस एलोकेट कर दिया
कोई प्रॉब्लम नहीं है बट क्योंकि एक पार्टीशन में एक ही प्रोसेस जा सकती है बचा हुआ जो स्पेस है ये मान लीजिए 101
लोगों की टेबल थी बहन अकेले आके बैठ गए पूरा खुश है लेकिन ये स्पेस अब यूज नहीं हो सकता तो यह कहां होगा हमेशा फिक्स साइज
पार्टीशन में वेरिएबल साइज पार्टीशनिंग में देर नेवर बीन इंटरनल फ्रेगमेंटेशन अगर मैं पार्टीशन एगजैक्टली अपने हिसाब से
बनाता हूं और प्रोसेस पूरा फिल नहीं कर पाती तो थोड़ा लेफ्ट ओवर स्पेस जरूर बचेगा दैट इज इंटरनल फ्रेगमेंटेशन एरे आपने
डिक्लेयर किया 10 सेल का बाद में उसमें छह ही आप भर पाए बचा हुआ चार स्पेस किसी और को तो दे नहीं सकते वेस्ट हो गया ना दैट
इज एन एग्जांपल ऑफ इंटरनल फ्रेगमेंटेशन सो आई थिंक इंटरनल एक्सटर्नल दोनों फ्रेगमेंटेशन आपको समझ आए होंगे इन द लंगर
में आपको बता दूं हमारे लिए बिगर प्रॉब्लम क्या है हमारे लिए बिगर प्रॉब्लम होता है एक्सटर्नल फ्र टेशन उसमें बहुत स्पेस
वेस्ट होता है अब एक्सटर्नल फ्रेगमेंटेशन को सॉल्व कैसे करें दो आईडिया हो सकता है या तो आप रन टाइम में सिस्टम में प्रोसेस
जो अलग-अलग जगह पे है है ना उनको पसू करो उनको समझाओ कि यार बार-बार डी फ्रेगमेंट करो उनको एक एक जगह प लेके आके इकट्ठा करो
बट ये सुनने में आसान लग रहा है रन टाइम पे सिस्टम में बार-बार प्रोसेसेस को मूव करना एक
एप्रोप्रियेट में काम कर नहीं पाता तो उसको करने का का फिर बेटर तरीका क्या है कि आपको प्रोसेस को समझाना पड़ेगा कि
व्हाई डोंट यू गो फॉर नॉन कंटस एलोकेशन जिसकी मैं पहले बात कर रहा था तो नॉन कंटीन्यूअस पॉलिसी अगर हम प्रोसेस को
समझाएं वो मैनेज कैसे होगा प्रोसेस के टुकड़े करेंगे एड्रेस ट्रांसलेशन कैसे होगा पहले टुकड़े से अगले टुकड़े प कैसे
पहुंचेंगे वो सारी चीजें देखने वाली होंगी बट यही एक आईडिया है नॉन कंटस पॉलिसी का एक्सटर्नल फ्रेगमेंटेशन से बचने के लिए जो
हम करते हैं जिसका नाम है पेजिंग तो पहले इसकी बैकग्राउंड समझना जरूर पेजिंग कहां से आया हमारे लिए कंटस एलोकेशन में बड़ी
प्रॉब्लम है एक्सटर्नल फ्रेगमेंटेशन जिसके लिए नॉन कंटस तरीके से मेमोरी को मैनेज करते हैं जिसका सॉल्यूशन है पेजिंग अब
पेजिंग क्या है और नॉन कंटीन्यूअस काम कैसे करता है बड़ा इंपॉर्टेंट और थोड़ा सा मुश्किल भी है सारी बातें समझ के चलेंगे
थैंक यू तो चलिए अभी बात करते हैं नॉन कंटस मेमोरी एलोकेशन की यानी कि पेजिंग की तो पेजिंग की क्या व्यवस्था है पूरा
डायग्राम बहुत थोड़ा सा लंबा आईडिया है एक बार में सारी चीज नहीं समझ आएगी तो स्टेप बाय स्टेप मेरे साथ आगे बढ़ते रहिएगा
धीरे-धीरे सारी चीज आपको स्टेप बाय स्टेप क्लियर करते जाऊंगा आई विल गो पॉइंट बाय पॉइंट हियर स्पेसिफिकली वरना वो यू नो एक
पॉइंट एक्सप्लेन करते लगते हो कहानी लंबी निकल जाती है पेजिंग इज अ मेमोरी मैनेजमेंट स्कीम दैट परमिट्स द फिजिकल
एड्रेस अ स्पेस ऑफ अ प्रोसेस टू बी नॉन कंटस पूरा आर्गुमेंट यही है हमें प्रॉब्लम है एक्सटर्नल फ्रेगमेंटेशन से और
एक्सटर्नल फ्रेगमेंटेशन जो हमने समझा वो हो रहा है कंटस एलोकेशन से तो उसको रिजॉल्व करने के लिए हम ये मेथड यूज कर
रहे हैं बात समझ आती है है एंड पेजिंग इज देयर टू रिमूव एक्सटर्नल फ्रेगमेंटेशन तो जब भी पेजिंग की बात करें पहले समझाए कि
भाई पेजिंग है क्या नाउ अब हम काम करेंगे कैसे देखिए डिवाइड कर रहे है ना मेमोरी को कैसे डिवाइड करेंगे सबसे पहले जो सेकेंडरी
मेमोरी है हमारी उसको हम डिवाइड करेंगे कुछ पार्टीशंस में यस जैसा हमने एक एग्जांपल देखा रेस्टोरेंट वाला अलग-अलग
टेबल्स अलग-अलग साइज की हो सकती है बट यहां पर टू मेक द थिंग सिंपल वी विल बी यूजिंग नॉट वेरिएबल साइज बट फिक्स साइज
पार्टीशनिंग पॉइंट नंबर वन पॉइंट नंबर टू फिक्स साइज पार्टीशन में भी इन सब पार्टीशन का साइज आपस में भी सेम होगा
ताकि मैनेज करना आसान हो धीरे-धीरे डिस्कशन आगे बढ़ेगा आप समझ जाएंगे जैसे बराबर साइज के पार्टीशंस सेकेंडरी मेमोरी
में होंगे ठीक सेम साइज के पार्टीशन मेन मेमोरी या फिजिकल मेमोरी में भी होंगे तो मान लीजिए अगर इधर पार्टीशन का साइज 1kb
है ना सर तो इधर भी पार्टीशन का साइज 1kb ही रखेंगे ताकि इनको आपस में मैनेज करना आसान हो बार-बार स्वप इन करना है बार-बार
स्वप आउट करना है तो फिक्स साइज पार्टीशन ईच पार्टीशन इज ऑफ सेम साइज यहां पर सेकेंडरी में इस पार्टीशन को आज के बाद
में कह के बुलाऊंगा पेज और यही रीजन है इस पूरी स्कीम को हम पेजिंग कह रहे हैं यही पार्टीशन जब हम मेन मेमोरी में पढ़ेंगे तो
इसको हम बोलते हैं फ्रेम तो आज के बाद आपको याद हो गया फ्रेम क्या है और पेज क्या है बस मेमोरी को इक्वल साइज
पार्टीशंस में डिवाइड कर दिया वही पॉइंट लिखा हुआ है सेकेंडरी मेमोरी इज डिवाइडेड इनटू फिक्स साइज पार्टीशन बिकॉज़
मैनेजमेंट इज इजी एंड ऑल ऑफ देम आर ऑफ़ सेम साइज कॉल्ड एज पेजेस एंड सिमिलरली यहां पर जब हम बात करते हैं दे आर कॉल्ड
एज फ्रेम्स यस ये बात समझ आ गई इन जनरल फिजिकल मेमोरी रिलेटिवली बहुत अ छोटी होती है कंपेयर टू जैसे मैंने अपने ए सिस्टम का
एग्जांपल आपको दिखाया था तो मेरे सिस्टम में फिजिकल मेमोरी रैम जो है वो है 32gb की और हार्ड डिस्क जो है वो 8 टेराबाइट की
तो कई गुना का डिफरेंस है दोनों के बीच में लेकिन साइज फिर भी सेम है फ्रेम्स का तो यानी कि यहां पे नंबर ऑफ फ्रेम्स छोटे
होंगे यहां पे नंबर ऑफ़ फ्रेम बड़े होंगे जैसे अब मान लीजिए होटल में कोई रूम है रूम आमतौर पर स्टैंडर्ड साइज का होता है
होटल छोटा होगा तो उसमें नंबर ऑफ रूम्स कम होंगे होटल बड़ा होगा तो नंबर ऑफ रूम ज्यादा होंगे बट रूम का साइज मोरल लेस सेम
रहेगा सेम लॉजिक यहां पे है आगे बढ़ता हूं अब ट्रांसलेशन कैसे होगा पूरा गेम ट्रांसलेशन का है पहले तो याद है रीलोकेशन
रजिस्टर लिमिट रजिस्टर ट्रांसलेशन बहुत आसान था यहां आसान नहीं होगा कैसे गौर करिए स्टेप नंबर वन सीपीयू जनरेट करेगा एक
एड्रेस और अब वो एड्रेस दो पार्ट में डिवाइड होगा प और डी यहां पर पी का मतलब है पेज नंबर एंड डी का मतलब है ऑफसेट कहने
का मतलब अब तक तो मैं बोल रहा था कि मेरे को यह वाला इंस्ट्रक्शन दो बट अब क्योंकि सेकेंडरी मेमोरी आपने पेजेस में डिवाइड कर
दिया है तो मैं क्या बोलूंगा मेरे को पेज नंबर थ्री का इंस्ट्रक्शन नंबर सेवन समथिंग लाइक दिस पेज नंबर इंस्ट्रक्शन
नंबर तो वही बोल रहा हूं गिव मी अ पेज नंबर गिव मी इंस्ट्रक्शन नंबर अब मजे की बात क्या है बहुत सारे
अप्रोचेबल लीजिए कोई प्रोसेस है जिसके पास p1 p2 p3 p 4 एंड p5 पांच पेज है अब यह जो पांच पेजेस है यह मेन मेमोरी में कहीं ना
कहीं होंगे अगर फिलहाल हम एग्जीक्यूट कर रहे हैं मान लेते हैं कि है लेकिन यह भी समझना पड़ेगा कि नॉन कंटीन्यूअस है तो ऐसा
हो सकता है कि यहां पर हो पेज नंबर वन इधर कहीं हो पेज नंबर टू इधर कहीं हो पेज नंबर थ्री नॉन कंटस फैशन में ऊपर नीचे किसी भी
ऑर्डर में हो सकता है पहुंचे कैसे इसके ऊपर अगर मैं ऐसा बोलूंगा कि पेज नंबर वन के पास एक लिंक होगा जो पेज नंबर टू फिर
पेज नंबर टू पेज नंबर थ्री तक पहुंचाएगा तो बड़ी दिक्कत हो जाएगी तो यहां पर हम क्या करते हैं हम एक टेबल बनाते हैं जिसको
बोलते हैं पेज टेबल अब पेज टेबल क्या है सर पेज टेबल कोई हार्डवेयर नहीं है समझिए यह भी एक डटा स्ट्रक्चर है और इस पेज टेबल
में कितनी एंट्री होंगी जितने किसी प्रोसेस के पास पेज है तो प्रोसेस के पास मान रम सेकेंडरी में कितने पेज है पांच
पेज है ना तो यहां देखिए पांच एंट्री मैंने पेज टेबल में बना ली और जैसे इंडेक्सिंग में हम करते हैं हर मेरा पेज
फिलहाल मेन मेमोरी में कहां पे सीध उसका एड्रेस है तो कैन आई से मान लीजिए पेज नंबर वन है इधर नंबरिंग चल रही होगी 1 2 3
4 5 6 समथिंग समथिंग लेट मी से मेरा पेज नंबर वन फ्रेम नंबर सेवन में है पेज नंबर टू मेरा फ्रेम नंबर टू में है पेज नंबर
थ्री मेरा फ्रेम नंबर फाइव में लाइक दिस तो मैं क्या करूंगा जैसे ही सीपीयू बोलेगा पेज नंबर ये चाहिए तो मुझे जाना पड़ेगा
पेज टेबल के पास हर प्रोसेस की अपनी एक पेज टेबल होगी उस पेज टेबल से मुझे पता लगेगा कि ओके आपका यह वाला पेज ना अभी मैं
मेमोरी में इस फ्रेम में है तो मेरे को क्या मिल गया देखो मेरे को मिल गया फ्रेम नंबर अच्छा पूरा पेज उठा के मैं मेन
मेमोरी में कहीं पे भी रख दूं पेज के अंदर जो इंस्ट्रक्शन है भला उसका एड्रेस कभी चेंज होगा कभी नहीं होगा तो इंस्ट्रक्शन
का एड्रेस मैं सेम एज इट इज ले लेता हूं और ये जो p और डी था ये बन जाएगा एफ और डी और ये बन जाएगा फिजिकल लेटर्स और अब इस
एड्रेस को यूज करके मैं अपना जो मेन मेमोरी है उसको एक्सेस करूंगा ये पूरी ट्रांसलेशन प्रोसेस है है ना इसको दो बार
रिवाइंड करके देखिएगा मैंने कोशिश की है कोई पॉइंट मिस ना किया हो आपसे अगर कोई छूटा है तो यू नो इट विल गेट कवर्ड वंस यू
रिवाइज मैं दोबारा पढ़ रहा हूं लॉजिकल लेटर्स दो पार्ट में डिवाइड किया पी और डी प का मतलब हुआ पेज नंबर डी का मतलब हुआ
इंस्ट्रक्शन ऑफ सेट पेज नंबर क्या है पेज नंबर इंडेक्स है पेज टेबल पे ये अच्छा ये भी एक डेटा स्ट्रक्चर है यह मैं बोल रहा
हूं हार्डवेयर नहीं ये खुद मेन मेमोरी में ही कहीं पे स्टोर है तो जब भी हम यू नो ट्रांसलेशन स्टार्ट करेंगे हमें पता होगा
कि इस प्रोसेस को जिसको हम रन कर रहे हैं उसका पेज टेबल कहां पे है एक रजिस्टर होता है मैंने यहां लिखा भी होगा कहीं पीटीबीआर
स्टैंड्स फॉर पेज टेबल बेस रजिस्टर जो मुझे इस टेबल तक पहुंचा देता है ताकि मैं इसको पढ़ सकूं अच्छा लिखा है ना अगला
पॉइंट वही है तो पेज टेबल बेस रजिस्टर प्रोवाइड द एड्रेस ऑफ़ द पेज टेबल एंड देन द करेस्पॉन्डिंग्ली
मेन मेमोरी में आपका फेज फिलहाल कहां पे रखा हुआ है देन अगेन इंस्ट्रक्शन ऑफसेट के साथ कंबाइन करते हैं और हमें मिल जाता है
हमारा फिजिक एड्रेस अब थोड़ी सी बात डिटेल में करते हैं पेस्ट टेबल के बारे में यस क्या पेस्ट टेबल एक हार्डवेयर है कि डेटा
स्ट्रक्चर है एक डेटा स्ट्रक्चर है क्या पेज टेबल सिस्टम का है कि प्रोसेस का है सर वो जो हमने प्रोसेस समझी उसके पास पांच
पेज थे तो उसके पेज टेबल में पाच एंट्री है किसी दूसरे प्रोसेस के पास हो सकता है 5 लाख पेज हो तो उसके प्रोसेस में कितनी
एंट्री होगी 5 लाख एंट्री होंगी सो सिस्टम के अंदर कितने पेज टेबल होंगे जितनी प्रोसेस है एवरी प्रोसेस विल हैव अ पेज
टेबल सेपरेट पेज टेबल है ना यह बात समझ आ गई नंबर ऑफ़ एंट्रीज अ अ प्रोसेस इन अ पेज टेबल इज़ द
नंबर ऑफ़ पेजेस अ प्रोसेस हैव इन द सेकेंडरी मेमोरी कितनी एंट्री होंगी जितने मेरे पास सेकेंडरी मेमोरी में पेजेस हैं
मान लीजिए मेरे पास 5 लाख पेज हैं तो इधर 5 लाख ही एंट्री होंगी हालांकि मैं बता दूं क्योंकि नॉन कंट्री केस लोकेशन है
क्या जरूरी है कि वह सारे के सारे पेजेस फ़िलहाल मेन मेमोरी में हो यह जरूरी नहीं है लेकिन वहां पे आपको इनवैलिड एंट्री मिल
जाएगी प्रॉब्लम क्या है लेकिन नंबर ऑफ़ एंट्रीज कितनी होंगी जितनी टोटल पेज मेरे पास है ओके साइज ऑफ ईच एंट्री इन द पेज
टेबल इज सेम एज द करेस्पॉन्डिंग्ली के अंदर ये तो पता समझने वाली बात क्या है जब पेजिंग यूज करके हम एक्सेस करते हैं ना
पेजिंग करते स्लो हो जाता है कैसे पहली ब बार जब आप पेज टेबल के पास जाएंगे खुद मेन मेमोरी में एक बार मेन मेमोरी एक्सेस करना
पड़ा अब यहां से आपको मिलेगा करेस्पॉन्डिंग्ली बिकॉज ऑफ दिस नॉन कंडिस एलोकेशन मुझे कम
से कम मेमोरी कितनी बार एक्सेस करना पड़ेगा दो बार एक्सेस करना पड़ेगा तब तो जाके मेरे को एड्रेस मिलेगा जो मुझे
एक्सेस करना है बट कोई बात नहीं कुछ पाने के लिए कुछ खोना पड़ता है कंक्लूजन से मिला क्या सिर्फ एक चीज
रिमूवल ऑफ एक्सटर्नल फ्रेगमेंटेशन और कभी-कभी समस्या इतनी बड़ी होती है कि उनकी कीमत चुकानी पड़ती है बट ट्रस्ट मी जब
धीरे-धीरे आप सिस्टम को ऑब्जर्व करेंगे समझेंगे यू विल अंडरस्टैंड ये एडवांटेज इतना बड़ा है कि ये सारी की सारी प्रॉब्लम
जो भी मिलेंगी ना पेजिंग के साथ उस पर हम काम करने के लिए तैयार रहते एडवांटेज बहुत बड़ा है एक और बात यह मैं कोई थियोरेटिकल
आईडिया नहीं पढ़ा रहा आज भी जिस लैपटॉप जिस फोन के थ्रू आप ये वीडियो देख रहे हैं ना उसके अंदर भी पेजिंग इंप्लीमेंटेड है
सो दिस इज नॉट एन आउटडेटेड ऑर्थोडॉक्स आइडिया जो कभी-कभी हमारी शिकायत रहती है ना पढ़ रहे हैं लेकिन इसका आज की दुनिया
से कोई लेना देना नहीं है है इवन और कॉम्प्लेक्टेड नुकसान क्या हुआ तो मैंने आपको समझा दिया ट्रांसलेशन बड़ा स्लो है
पहले तो याद है लिमिट और रीलोकेशन रेजिस्टर अर्थमेटिक ऑपरेशन था प्लस माइनस कंपैरिजन करना पड़ता था बहुत आसान था यहां
पर मेन मेमोरी कम से कम दो बार एक्सेस करनी पड़ती है तो सिस्टम की स्पीड हाफ हो जाती है फर्स्ट पॉइंट सेकंड पॉइंट अ
कंसीडरेबल अमाउंट ऑफ़ स्पेस इज़ वेस्टेड इन स्टोरिंग द पेज टेबल पेज टेबल को स्टोर करने में भी एक अच्छा खासा स्पेस हमारा
वेस्ट होता है यह बात तो ठीक है और पेज टेबल क्या है मेटा डेटा डेटा और मेटा डाटा बिकॉज़ इसके अंदर एगजैक्टली पेज नहीं है
डाटा नहीं है यह तो बता रहा है कि मेन मेमोरी में कौन सा पेज कहां पे है दिस इज एन आईडिया सिस्टम सफर्स फ्रॉम इंटरनल
फ्रेगमेंटेशन एज पेजिंग हां इंटरनल फ्रेगमेंटेशन हम पहले पढ़ चुके हैं तो इंटरनल फ्रेगमेंटेशन किस लिए होता है जब
भी फिक्स साइज पार्टीशन आप करेंगे इमेजिन करिए अगर कोई प्रोसेस है लेट मी से जिसका साइज
है 15 100 बाइट्स 1500 बाइट्स और मेरा जो पेज है वो 1 केब का है तो बोलो उस प्रोसेस को स्टोर करने के लिए कितने पेज एलोकेट
करने पड़ेंगे कम से कम दो तो करोगे ना वरना वो दूसरा जो 1500 वाला हिस्सा पूरा नहीं आएगा तो यहां पर जो दूसरा पेज है मान
लेता हूं पहला तो पूरा भर जाएगा बट क्या दूसरा पेज पूरा भरेगा दूसरा पेज पूरा नहीं भर पाएगा सो अगेन इट इज वेरी क्लियर कट
आईडिया कि इंटरनल फ टेशन तो होगा जहां भी फिक्स साइज पार्टीशनिंग होगी वहां इंटरनल फ्रेगमेंटेशन होगा बट यह वेस्टेज कंपेयर
टू पेजिंग कंपेयर टू एक्सटर्नल फ्रेगमेंटेशन बहुत कम है बहुत मेनेजेबल है आगे बढ़ता हूं ट्रांसलेशन इज डिफिकल्ट एंड
कॉम्प्लेक्टेड मानना चाहिए कि नहीं बट है तो यह प्रोसेस एक समय के बाद इतनी कॉम्प्लेक्टेड हमें करना पड़ता था फेयर
इनफ इससे पहले आगे बढ़े मैं बहुत ज्यादा इस वीडियो में कंसंट्रेट न्यूमेरिकल्स पे नहीं करूंगा लेकिन एक बेसिक आईडिया आपको
समझाता हूं खासकर यूनिट्स का बच्चे बड़े कंफ्यूज रहते हैं देखो रियल लाइफ़ में जब हम बात करते हैं ना तो हम थाउजेंड्स में
मिलियंस में बिलियंस में बात करते हैं रियल लाइफ के अंदर है ना अ आप सुनते हैं ना बिलियन डॉलर मिलियन डॉलर बल्कि मैं बात
करूं इंडिया में तो क्या है इंडिया में पहली ज़ीरो पहला कॉमा हम लगाते हैं तीन के बाद यह हुआ 1000 उसके बाद जब हम कॉमा
लगाते हैं हम दो-दो के बाद लगाते हैं हमें ऐसा समझना आसान होता है तो 1 लाख हुआ ना सॉरी ये 1000 था ये क्या हो गया 1 लाख हो
गया फिर दो के बाद और कॉमा लगाएंगे आई एम सॉरी ऐसा कर लेता हूं अब ये क्या हो गया ना दैट विल बी 1 करोड़ है ना
दो दो के बाद कॉमा लगता है बाहर आप देखेंगे तो तीन-तीन के बाद ही कॉमा लगता है नाउ दिस इज 1000 अभी तीन के बाद लगा
देंगे नाउ दैट इज 1 मिलियन फिर तीन के बाद लगा देंगे सो नाउ दैट इज 1 बिलियन लाइक दिस फिजिक्स में जब हम पढ़ते हैं तो 10 की
पावर 3 का सिस्टम चलता है 10 की पावर 3 10 की पावर 6 बट थाउज मिलियन बिलियन ट्रिलियन ना बोल के किलो मेगा गीगा टेरा पेटा ऐसे
बोलते हैं कंप्यूटर साइंस में हम 10 की पावर से नहीं खेलते हम टू की पावर से खेलते हैं ये एगजैक्टली सेम नहीं होता 2
की पावर 10 एकदम 1000 नहीं होता ये होता है 1024 है ना बट इसको हम क्या बोलते हैं इसको किलो बोलेंगे इसको मेगा बोलेंगे इसको
गिगा बोलेंगे तो हम जब भी बात कर रहे होते हैं ना किलोबाइट मेगाबाइट गीगाबाइट टेराबाइट तो गीगाबाइट से कभी भी मेरा मतलब
10 की पावर 9 नहीं होगा गीगाबाइट से हमेशा मेरा मतलब क्या होगा 2 की पावर 30 होगा तो हमारा भगवान टू है भाई हम टू की पावर में
खेलेंगे है ना ये यूनिट का अंडरस्टैंडिंग मुझे लगता है कि आपको होना चाहिए छोटा सा एक अंडरस्टैंडिंग आपको कराता हूं मेमोरी
का देखो एड्रेस को स्पेस में स्पेस को एड्रेस में बेसिक ट्रांसलेशन करना आपको आना चाहिए यहां मैं क्या समझाना चाह रहा
हूं यहां देखो नंबर ऑफ एड्रेस एड्रेस लेंथ एन बिट्स फॉर एग्जांपल मान लीजिए मेरे पास दो बिट है बताओ दो बिट से कितना कॉमिनेशन
बनेगा सर दो बिट से चार बन सकता है 0 0 बनेगा 0 1 बनेगा 1 0 बनेगा 1 1 बनेगा मानते हो अगर मेरे पास तीन बिट है तो
कितना कॉमिनेशन बनेगा 00 00 1 010 01 1 1 101 110 1111 इजेंट इट तीन से कितने बने आठ बने ये मैं करना नहीं चाह रहा चार से
कितने बनेंगे 16 कॉमिनेशन तो आपको क्या समझना है अगर आपके पास कोई एड्रेस n बिट्स का है है ना तो यूजिंग दैट आप कितनी
लोकेशन को पॉइंट कर सकते हो 2 ^ n को तो अगर मेरे पास n बिट्स हैं अगर मेरे पास 4 बिट्स हैं तो 2 ^ n यानी मैं 16 को पॉइंट
कर सकता हूं अब इससे एग्जांपल क्या बनता है मान लीजिए क्वेश्चन में लिखा होगा सपोज दैट यू हैव अ एड्रेस ऑफ़ 32 बिट कितने बिट
का एड्रेस है 32 बिट का बताओ मेमोरी का साइज़ क्या है तो कैसे निकालो क्योंकि 32 बिट का एड्रेस है इस मैथ से आप क्या समझे
बताओ मेमोरी में कितनी लोकेशन होंगी सर मेमोरी में टू 2 रे टू पावर 32 लोकेशंस होंगी मानते हो इस बात को आमतौर पे या तो
वो बताएगा वरना डिफॉल्ट केस में हम मान के चलते हैं कि ईच लोकेशन इज ऑफ व बाइट कितना व बाइट तो टोटल मेमोरी का साइज क्या होगा
नंबर ऑफ लोकेशन मल्टीप्ला बाय साइज ऑफ ईच लोकेशन सो नंबर ऑफ लोकेशन इज 2 रे टू पावर 32 एंड साइज ऑफ ईच लोकेशन इज 1 बाइट सो
दिस इज 2 रे टू पावर 32 बाइट इसको कैसे लिखूं कैन आई राइट 2 रे टू पावर 2 * 2 रे पावर 30 बाट व्हाट इज 2 रे पाट दिस इज 4
व्हाट इज 2 रे टू पावर 30 इट इज गीगा तो व्हाट इज द कैपेसिटी नाउ 4 गगा बाइट कैपेसिटी हो गई हमारी किसकी मेमोरी की ये
एक बेसिक अंडरस्टैंडिंग मैं चाहता हूं आपको हो और इसी तरह इसका रिवर्स भी हो अगर मैं आपसे बोलूं समथिंग लाइक दिस मैं आपसे
बोलूं कि मेरे पास एक मेमोरी है सपोज सपोज सपोज कितना लेते हैं 512 मेगाबाइट फॉर एग्जांपल अब मैं आपसे
पूछूं मुझे बता सकते हो एड्रेस का लेंथ क्या होगा कैसे निकालेंगे देखो अगर पूरे मेमोरी का साइज
512 मेगाबाइट है और डिफॉल्ट केस में हम मान के चल रहे ईच लोकेशन इज 1 बाइट तो बताओ नंबर ऑफ लोकेशन कैसे निकालूं सो नंबर
ऑफ लोकेशन इज लाइक साइज ऑफ मेमोरी डिवाइडेड बाय साइज ऑफ लोकेशन 512 टोटल है एक लोकेशन 1 बाइट का है तो टोटल लोकेशंस
कितनी हुई टोटली 512m व्हाट इज 512 सर 512 इज 2 रेट पावर 9 व्हाट इज m m इज 2 रेट पावर 20 सो तो
व्हाट डू यू गेट 2 रे टू पावर 29 लोकेशंस है अब आपने पूरी मैथ समझी है पहले n था 2 की पावर n किया अभी 2 की पावर तो लॉग
करूंगा तो लॉग बेस 2n करूंगा तो बेसिकली व्हाट आई गेट 29 बिट्स तो अगर एक मेमोरी है जिसमें जिसका कैपेसिटी 512 एब है तो
वहां पे जो एड्रेस का लेंथ होगा वो 29 बिट्स का होगा जहां कंफ्यूजन हो पीछे जाना चला के देखना पीछे जाना चला के देखना
एक-एक बात डिटेल में मैंने यहां पे समझाई है बाकी कंप्लीट प्लेलिस्ट तो आप आपके पास है ही है फेयर इनफ तो यूजिंग दिस आईडिया
अब अगर मैं यह टेबल को कंक्लूजन का साइज क्या होगा फिर वई बात कितनी एंट्रीज है नंबर ऑफ एंट्रीज
मल्टीप्लाई बाय साइज ऑफ ईच एंट्री ऐसा आप करेंगे तो आपको क्या मिल जाएगा पेस्ट टेबल का साइज अच्छा प्रोसेस का साइज पेस्ट टेबल
का साइज अलग बात है प्रोसेस का साइज प्रोसेस में कितने पेज हैं हर पेज का क्या साइज है प्रोसेस का साइज निकाल सकते हैं
पेस्ट टेबल तो सिर्फ प्रोसेस का एक मेटा डाटा है इस तरह से कुछ मैंने फिल इन द बनाया है आप इसे प्रैक्टिस करके देखना
कमेंट में मेरे को आंसर करके बताना एक मैं सॉल्व कर देता हूं जैसे इसने बोला सेकेंडरी मेमोरी 32 गीगाबाइट अब आपको
तुरंत दिमाग चलना चाहिए जो आपको समझाया ना 32 गीगाबाइट अगर है एक लोकेशन न बाइट का है लिखा ना वन बाइट एड्रेस बल हाउ मेनी
लोकेशंस आर देर 32 गीगा व्हाट इज 32 2 की पावर 5 व्हाट इज गीगा 2 की पावर 30 तो टोटल लेंथ जो हो गई वो हो गई 2 की पावर 5
ना यस टोटल लेंथ हो गया 30 35 2 रे टू पावर 30 गीगा एंड यस टोटल लेंथ हो गया कितना 35 बिट तो ये आ गया लॉजिकल एड्रेस
का लेंथ आगे देखो क्या बता रहा है वो बता रहा है यहां पे देखो वन एक पेज जो है वो 1kb का है अगर एक पेज 1kb का है फिर वही
बात है साइज ऑफ लोकेशन क्या है वन बाइट तो एक पेज के अंदर कितनी लोकेशन है 1k 1k मतलब 1024 इसका मतलब यहां पर कितनी बिट
चाहिए होंगी 10 बिट चाहिए ऑफसेट बताने के लिए पेज के अंदर 1024 में से कहां जाना है 35 टोटल तो बोलो कितना बचेगा सर यह बचेगा
25 ये डिकोड हो गया इधर आ जाओ भर लेंगे इसको बाद में ये इधर आ जाओ फिजिकल एड्रेस मेमोरी का लेंथ देखो मेमोरी का साइज कितना
128 मेगाबाइट एक लोकेशन का कैपेसिटी 1 बाइट 128 2 रेट पावर 7 m 2 रेट पावर 20 टोटल लेंथ कितना हुआ
27 ऑफसेट तो सेम रहेगा दोनों जगह तो इधर इसको 10 कर देता हूं 27 से 10 गया बोलो कितना बचा सर 17 बचा कुछ बचा है क्या करने
के लिए तो व्हाट इज द लेंथ ऑफ द फिजिकल लेटर्स इज 27 p का लेंथ कितना है दिस इज 25 फ्रेम का लेंथ कितना है सर दिस इज 17
ऑफसेट कितना आया दिस इज 10 यस तो लाइक दिस आप बचे हुए टेबल फिल करके कमेंट सेक्शन में बात कर सकते हो इसके ऊपर आगे बढ़ता
हूं अब एक-एक प्रॉब्लम के ऊपर बात करते हैं यस तो पहली जो बड़ी प्रॉब्लम थी पेजिंग की वो क्या था टाइम टाइम बहुत स्लो
हो रहा है उस टाइम का एक सॉल्यूशन है उसको फास्ट करने का द सॉल्यूशन इज टीएलबी व्हाट इज टीएलबी ट्रांसलेशन लुक अाइड बफर सो ये
कोई डेटा स्ट्रक्चर नहीं है ये एक हार्डवेयर है ट्रांसलेशन लक साइट बफर नाउ दैट इज अ स्पेशल पर्पस हार्डवेयर और ये एक
तरह का कैश है ये मैकेनिज्म इस तरह के आइडियाज हम पहले भी कई बार यूज करते हैं तो ये कैसे काम करता है पहली बार आप
बोलोगे मेरे को एक पेज नंबर फॉर एग्जांपल पेज नंबर से का बताओ क्या एड्रेस क्या है तो हम गए हमें पता लगा पेज नंबर सेवन जो
है वो फ्रेम नंबर 17 में है तो हम क्या करेंगे छोटा सा बफर बनाएंगे और फिलहाल ये याद रख लेंगे अच्छा पता है क्या पेज नंबर
सेवन ना फ्रेम नंबर 17 में है क्योंकि लोकैलिटी ऑफ रेफरेंस हमें सिखाता है कि एक पेज एक बार तो रन होगा नहीं एक पेज में 1
1500 इंस्ट्रक्शन होंगी अगर एक बार एक्सेस इस बात के काफी चांस है कि अगली बार भी एक्सेस हो अब प्रोसेस अगली इंस्ट्रक्शन
मांगेगी अगर जिसके ज्यादातर चांस है कि वो सेम इंस्ट्रक्शन मांगे पेज नंबर सेवन तो हम तुरंत बोल देंगे पता है पेज नंबर 717
में है मुझे मेन मेमोरी में जाने की जरूरत नहीं है दिस स्टेबल स्टोर्ड इन द मेन मेमोरी जिसको एक्सेस करना स्लो है टीएलबी
तो बड़ा फास्ट है ना यार यहीं से उठा के डायरेक्ट एक्सेस कर सकता हूं ये एडवांटेज अब होगा क्या जब दो-चार मिनट ये प्रोसेस
चल जाएगी धीरे-धीरे पूरा टीएलवी भर जाएगा और आमतौर पे हम क्या ऑब्जर्व करते हैं 90 पर से ज्यादा केस में जब आप सर्च करोगे तो
आपको मैं करेस्पॉन्डिंग्ली से फ्रेम नंबर मिलेगा कम कंबाइन करो गो एक्सस द मेन मेमोरी अगर मिस हुआ जो कि
कभी-कभी होगा तो आपको नीचे जाना पड़ेगा बट ओवरऑल जब हम इसे लॉन्ग रन में चला के देखते हैं तो हमें एडवांटेज नजर आता है और
हमें समझ आता है कि यार ये टीएलबी के साथ जो एक बड़ा डिसएडवांटेज हमारा था वो डिसएडवांटेज पूरा हो रहा है ये सारे वही
थोरेट्स मेंशन है यू कैन गो इन टू ईच ऑफ देम वन बाय वन आपको पूरी बात समझ आएगी फार्मूला बाजी वैसे मैं विश्वास नहीं करता
बट स्टिल अगर आप फिल्म वर्क समझ रहे हैं बताओ क्या होगा अगर हिट हुआ फॉर एग्जांपल हिट होने की कोई रेशो है मैं लिख देता हूं
मान लेते हैं कि 90 पर केस में हिट हो रहा है तो मैं क्या लिखूंगा मेरा हिट रेशो 9 पर केस में टाइम न्यूमेरिकल बना लेते हैं
लेट मी से 10 ननो सेकंड लगता है अगर टीएलबी हिट हो अगर टीएलबी मिस हुआ मेन मेमोरी के पास जाना पड़ा तो 100 ननो सेकंड
लगता है तो अगर हिट हुआ 10 ननो सेकंड मेन मेमोरी का 100 ननो सेकंड 110 में काम हो जाएगा 90 पर ऑफ द केस में लेकिन कभी-कभी
हिट नहीं होगा जो कि कितना हो जाएगा 1-9 अब पहले टीएलबी का पेनल्टी तो लगा आप पे बिकॉज़ एक्सेस करने के बाद ही तो पता लगा
ना कि डाटा नहीं है अब फिर से जाना पड़ेगा पेज टेबल के पास और जब पेज टेबल से करेस्पॉन्डिंग्ली
कितनी बार एक्सेस करना पड़ेगा टू टाइम्स इसे अब सॉल्व भी कर लो जब पूरा हो गया तो ये कितना है
110 और ये है नाइ तो कर लेना चलो जो भी वैल्यू आएगी इसमें स्पीड से चलना है बट ये ऑब् वियस 200 नहीं आएगा उससे बहुत कम है
सेटल करेंगे तो जो प्रॉब्लम था वो हमने काफी हद तक सॉल्व कर दिया टीएलबी वाला इशू नाउ एक प्रॉब्लम है पेज का साइज पेज का
साइज इस पूरे गेम में बड़ा इंपॉर्टेंट है क्यों मैं आपको समझाता हूं देखो अगर पेज का साइज हम बहुत बड़ा कर दें लेट मी से वी
हैव अ लार्ज पेज साइज उससे पेज टेबल का साइज कम होगा क्योंकि टोटल साइज तो कांस्टेंट है पेज जितने बड़े-बड़े होंगे
नंबर ऑफ पेजेस उतने कम होंगे तो पेज काउंटिंग में कम हो जाएंगे जिससे पेज टेबल को क्या करना पड़ है पेज टेबल को सब पेज
का हिसाब किताब रखना पड़ता है तो पेज टेबल छोटा हो जाएगा लेकिन प्रॉब्लम क्या होगा पेज का साइज बड़ा होने से इंटरनल
फ्रेगमेंटेशन होने के चांस बढ़ जाएंगे अगर कॉपी बहुत बड़ी है आपकी बड़े-बड़े पेजेस हैं और मान लीजिए लास्ट चैप्टर की आखिरी
लाइन ही आई बस एक पेज प पूरा पेज तो वेस्ट हो गया ना मेरा तो इंटरनल फ्रेगमेंटेशन बढ़ेगा इंटरनल फ्रेगमेंटेशन बढ़ेगा अगर
पेज का साइज बड़ा है लेकिन वेस्टेज बिकॉज ऑफ पेज टेबल कम होगा अगर पेज का साइज मैं बहुत छोटा कर दूं तो मेरा इंटरनल
सेगमेंटेशन तो नेगलिजिबल हो जाएगा ना के बराबर वेस्टेज नहीं हो रहा लेकिन उसमें प्रॉब्लम क्या है इतने सारे पेज हो जाएंगे
उनकी मैनेजमेंट जो पेज टेबल का साइज है उनका जो लेखा जोखा है उसमें बहुत स्पेस वेस्ट होगा तो अगर ये स्कीम सक्सेसफुल
इंप्लीमेंट करनी है तो अपने को क्या चाहिए हमें एक ऐसी वैल्यू मिले जो ना ज्यादा बहुत बड़ी हो जो ना ज्यादा बहुत छोटी हो
तो जहां पे हम अपना जो अ वेस्टेज है ऑफ डाटा आइर बिकॉज ऑफ द इंटरनल फ्रेगमेंटेशन और बिकॉज़ ऑफ द पेस्ट टेबल उसको मेंटेन कर
सके तो दैट इज आल्सो एन इंपोर्टेंट पॉइंट अच्छा नाउ कमिंग टू वन मोर आईडिया नाउ मल्टीलेवल पेजिंग इस तरह के कांसेप्ट बस
आपको टेस्ट आना चाहिए इनके ऊपर न्यूमेरिकल तो कॉम्पिटेटिव एग्जाम में नहीं पूछे जाते तो यूनिवर्सिटी या सेमेस्टर्स में तो बहुत
सिंपल अंडरस्टैंडिंग चाहिए मैं बस थोड़ा सा फ्रेमवर्क समझाता हूं क्या है इसको ऐसे समझना आप डायग्राम तो आपको याद करना ही है
बना के आना है कभी-कभी क्या हो सकता है पेस्ट टेबल बहुत बड़े हो सकते हैं हा या ना अब अगर किसी प्रोसेस के पास 10 लाख पेज
है एक यह सारा का सारा आपको भरना है पेस्टल के अंदर इतनी बड़ी पेस्ट टेबल कैसे एक्सेस करेंगे उसको मेन मेमोरी में स्टोर
भी नहीं कर पाएंगे क्योंकि वो एक फ्रेम में फिट नहीं होगी उस केस में हम क्या करते हैं उस पेज टेबल के भी टुकड़े कर
लेते इसको बोलते हैं मल्टीलेवल पेजिंग मैं इसको आसान शब्दों में ऐसे समझाता हूं इंस्ट्रक्शन नंबर है ऑफसेट हमारा अभी तक
हम बात कर रहे थे पेज नंबर में अगर पेज नंबर भी इतने सारे हो गए टीचर कह रहा गो टू पेज नंबर
648 बच्चा 6 6 लाख पेज कहां जाएगा तो उसको ऐसे समझ लो ना चैप्टर नंबर फर्द डिवाइड कर लिया तो पेस्ट टेबल के हमने टुकड़े कर लिए
अलग-अलग इमेजिन करो यही यही मान लो एक बड़ा सा पेस्ट टेबल है इसके टुकड़े कर लिए हमने और डिवाइड कर दिया ये चैप्टर नंबर वन
है चैप्टर नंबर टू है चैप्टर नंबर थ्री है चैप्टर नंबर फोर है लाइक दिस अब जब सीपीयू एटर जनरेट करेगा तो कैसे करेगा सोचो सीपी
बोलेगा चैप्टर नंबर दिस अब मेरे पास जो पेस टेबल बेस रजिस्टर की एंट्री होगी वो मुझे कहां लेके जाएगा वो मुझे पहली आउटर
पेज टेबल पे लेके जाएगा जहां पे ये पता होगा कि चैप्टर नंबर वन चैप्टर नंबर टू चैप्टर नंबर थ्री का डाटा की पेज टेबल
कहां पे है हर किसी की अलग पेज टेबल होगी तो मैंने बोला चैप्टर नंबर थ्री पे लेके चलो तो ये मुझे वो एड्रेस देगा मेमोरी के
अंदर ये वाला एड्रेस जहां से चैप्टर नंबर थ्री का पेज टेबल है फिर आप मुझे बोलोगे चैप्टर नंबर थ्री पेज नंबर टू पे जाना है
इन दोनों को मैं सम कर लूंगा तो सीधे पेज नंबर टू पे पहुंच यहां से मुझे मिलेगा कॉरस्पॉडिंग फ्रेम नंबर ऐड करूंगा खाना
पना खाऊंगा मजे ले लूंगा बात समझ आई कि नहीं आई तो लाइक अच्छा कोई बोले सर दो लेवल हो सकते हैं भाई तीन कर ले अगर
चैप्टर बहुत ज्यादा है यू कैन हैव वॉल्यूम 12थ क्लास में आरडी शर्मा भूल गए वॉल्यूम तो वॉल्यूम नंबर दिस चैप्टर नंबर दिस पेज
नंबर दिस इस तरह से हम मल्टी लेवल पेजिंग करते हैं बेसिक मैथ इसकी इतनी ही है पूरी बात आपको समझ भी आई होगी बाकी ये सेम ही
डायग्राम है ये एग्जांपल है थ्री लेवल पेजिंग का देखो वही हो रहा है हर बार अगले लेवल तक पहुंचाता हूं और इस तरह से आगे
बढ़ता हूं तो अगर कोई आपसे बात करे पांच नंबर में छह नंबर सात नंबर में लिखने के लिए पूछे तो आप इस पर लिख के आ सकते हैं
यस अगला आईडिया आ जाता है सेगमेंट अब सेगमेंटेशन की क्या कहानी है सुनिए देखिए पेजिंग जो है नॉन कं भूलिए मत अभी हम क्या
पढ़ रहे हैं मेमोरी को मैनेज करने के दो तरीके हैं कंटस और नॉन कंटस कंटस हम पढ़ चुके हैं नॉन कंटीन्यूअस में हमने पढ़ा
पेजिंग लेकिन कुछ लोग को ऐसा लगता है पेजिंग और नॉन कंटस दोनों एकदम सिनोनिम है मानो नॉन कंटस तो पेजिंग ही होगा पेजिंग
है तो नॉन कंटस होगा नहीं नॉन कंटस की एक और अप्रोच भी है जिसका नाम है सेगमेंटेशन हालांकि हम इसको पढ़ते हैं और फिर समझते
हैं कि ये बेकार है है फिर हमें समझ आता है कि हमें इसे नहीं पढ़ना चाहिए था लेकिन इसका थोड़ा सा आईडिया इंपॉर्टेंट है
क्योंकि एग्जाम में कभी-कभी पूछा जा सकता है तो आईडिया समझाता हूं थॉट प्रोसेस क्या है सेगमेंटेशन के ऊपर कि जब हम पेजिंग
करते हैं ना जैसा हमने किया था हम सिस्टम को एकदम बराबर बराबर बराबर साइज के पार्टीशन में डिवाइड कर देते हैं यही
कांसेप्ट है ना पेजिंग का तो उनका कहना है कि इसमें आपने प्रोग्रामर का व्यू नहीं लिया अगर प्रोग्रामर के हिसाब से सोचिए तो
मान लीजिए वो कह रहेगा मेरा प्रोग्राम है जिसमें कहीं मेन प्रोग्राम है कहीं सब रूटीन है स्टैक है सिंबल टेबल्स है तो
इंस्टेड आप इसे बराबर बराबर डिवाइड करो जैसे एक किताब में कहानियां है कोई छोटी हो सकती है कोई बड़ी हो सकती है अब आपने
बराबर बराबर डिवाइड कर दिया तो कहानी अलग-अलग पेज में बिखर गई आप कह रहे हो नहीं आप इसे ऐसे मत डिवाइड करो आप इसे
प्रोग्रामर व्यू से डिवाइड करो जो कहानी लंबी है उसका पेज बड़ा हो जो कहानी छोटी है उसका पेज छोटा हो एक प्रोसेस के लिए या
एक कंपोनेंट के लिए एक पेज हो और ये जो वेरिएबल साइज के पेज होंगे उसी को सेगमेंट कहेंगे दैट इज आ आईडिया तो मैं बोल सकता
हूं कि अगर पेजिंग को फिक्स साइज ना करके वेरिएबल साइज बनाया जाए बेस्ड ऑन द राइटर पॉइंट ऑफ व्यू तो जो बचता है दैट इज कॉल्ड
सेगमेंटेशन वही सारा पॉइंट मैंने यहां पे लिखा है पेजिंग इज अनेबल टू सेपरेट वही यूजर्स का जो पॉइंट ऑफ व्यू है वो करने के
लिए तो इस तरह से अगर हम डिवाइड करें लॉजिकल लेटर्स को देन दिस इज कॉल्ड सेगमेंटेशन अब इसमें प्रॉब्लम क्या है
इसमें प्रॉब्लम फिर वही पुरानी है पेज का साइज सेम था सबका तो मेरे लिए ट्रांसलेशन करना बड़ा आसान था अब यहां पे कौन सा
सेगमेंट बड़ा है कौन सा सेगमेंट छोटा सारी व्यवस्था देखनी पड़ेगी तो जैसे पहले हम कंटी केस लोकेशन करते थे उस तरह की स्कीम
बनेगी मेरे पास सेगमेंट टेबल होगा जहां पे हर सेगमेंट का लिमिट और सेगमेंट का बेस रजिस्टर लिखा होगा आप सीपीयू एड्रेस पेज
नंबर ऑफसेट ना करके सेगमेंट नंबर ऑफसेट में करेगा तो एस और डी में आपने फॉर एग्जांपल मुझे बोला सेगमेंट नंबर थ्री का
इंस्ट्रक्शन नंबर फाइव अब मैं जाऊंगा सेगमेंट टेबल के पास और देखूंगा सेगमेंट नंबर थ्री की लिमिट है मान लीजिए 10 और
बेस एडस है 1200 इसका मतलब सेगमेंट नंबर थ्री में 10 इंस्ट्रक्शन है आपने मांगा है ऑफसेट फाइव क्या आप लिमिट में है हां
लिमिट में वरना आपको यही ट्रैप कर लेता तो आपने मांगा आपने मांगा फाइव तो आप बिल्कुल लिमिट में परमिट करता हूं लेकिन यह बता
रहा है कि सेगमेंट नंबर थ्री जो है उसका बेस एड्रेस 1200 है आपको चाहिए पाच तो क्या हो जाएगा 1205 हो जाएगा और आप जाके
इसको एक्सेस कर लेंगे दिस इज एन आईडिया मेरे ख्याल से पूरी बात समझ आ रही है आपको सो इस तरह से जब हम इस पूरे प्रोसेस प काम
करते हो दैट इज कॉल्ड सेगमेंटेशन ये पूरी मैथ यहां पर लिखी है प्रॉब्लम क्या है सर सेगमेंटेशन क्योंकि कंटीन्यूअस है क्या
मैं एक सेगमेंट के टुकड़े कर सकता हूं कभी-कभी सेगमेंट बहुत बड़े हो सकते हैं ना नहीं कर सकता तो वैसे ही नॉन कंडिस पॉलिसी
है बट क्योंकि नॉन कंटस मतलब प्रोसेस के टुकड़े कर लिए सेगमेंट में बट सेगमेंट तो अपने आप में कंटीन्यूअस है ना ये देखो ये
कंटस है ये कंटस है ये कंटस है जिसकी वजह से मुझ पर दोबारा एक्सटर्नल फ्रेगमेंटेशन होने लगता है ऐसा हो हो सकता है ना मेरे
पास स्पेस हो बट इतना बड़ा ना हो कि ये सेगमेंट में एक जगह स्टोर कर पाऊ प्रॉब्लम तो भाई ये पूरी कहानी पड़ी क ती एक्सटर्नल
फ्रेगमेंटेशन हटाने के लिए और अगर ये मेरे ऊपर फिर से बनी रही तो इस बात का कोई मतलब बनता नहीं है तो हम इस पॉलिसी को पढ़ते हु
बोलते हैं नहीं मजा नहीं आया लेकिन कंक्लूजन आईडिया पे वो क्या है सेगमेंटेशन विद पेजिंग जो कि लास्ट आईडिया है इस मेथड
का इस अप्रोच का मतलब क्या है मेरे को सेगमेंट अच्छा तो लगा आईडिया सेगमेंट का आईडिया अच्छा था लेकिन मैं सेगमेंट को
दोबारा में डिवाइड करना चाहता हूं मतलब समझिए जब आपकी बुक में चैप्टर होते हैं तो चैप्टर होते हैं कि नहीं होते हैं होते
हैं बट क्या सारे चैप्टर सेम साइज के होते हैं नहीं जो कहानी छोटी होगी उसका चैप्टर छोटा होगा जो कहानी बड़ी होगी उसका चैप्टर
बड़ा होगा सर चैप्टर की बात तो हमने मल्टीलेवल पेजिंग में भी पढ़ी थी लेकिन मल्टीलेवल पेजिंग के सारे चैप्टर सेम साइज
के होते हैं जब हम सेगमेंटेशन विद पेजिंग करते हैं तो यहां पर हम क्या मैथ लगाते हैं कि दे यस देयर विल बी सेगमेंट्स बट
सेगमेंट विल बी फर्द डिवाइडेड इनटू पेज तो सेगमेंट भी नॉन कंटस हो सकते हैं तो डायग्राम एकदम सेम है टू बी वेरी नेस्ट
कोई चेंज नहीं है बस यहां पे सेगमेंट नंबर लिख दीजिएगा ये सारे पॉइंट्स मैं यहां पर लिखते चल रहा हूं इसमें से आधा भी लिख के
आएंगे तो आपका काम बन जाएगा यस सो दैट इज आइडिया वि सेगमेंटेशन विथ पेजिंग एक आखिरी अप्रोच और है कभी-कभी कॉलेज में मैंने
देखा है सेमेस्टर में पूछते हैं इनवर्टेड पेज टेबल क्या है ये बिल्कुल डिफरेंट आइडिया आईडिया यह है कि मेन मेमोरी में
हमने हर प्रोसेस के बड़े-बड़े पेज बना लिए लेकिन फैक्ट ये है क्या हर प्रोसेस एक टाइम में मेन मेमोरी में हो सकती है क्या
नहीं तो एक बड़ा सा पेज टेबल मेरे पास है जिसमें हो सकता है 100000 एंट्री हो गिनती के चार पेज ऐसे हैं जो अभी मेन मेमोरी में
है तो चार एंट्री वैलिड रखने के लिए इतने बड़े-बड़े डाटा स्ट्रक्चर बना के रखना कोई अकल मंदी नहीं है इसको अगर उल्टा रखा जाए
तो वो क्या है सर उल्टा ऐसे रखते हैं कि हम एक पेस्ट टेबल बनाएंगे बट इस बार यह पेस्ट टेबल सिस्टम की होगी प्रोसेस की
नहीं होगी और इस पेस्ट बबल में कितनी एंट्री होंगी जितने मेरे पास फ्रेम है तो फ्रेम नंबर वन फ्रेम नंबर टू फ्रेम नंबर
थ्री टिंग टिंग टिंग टिंग टिंग मान लीजिए n नंबर ऑफ फ्रेम से मैंने बना दिया अब सीपीय जो बैटर जनरेट करेगा सीपीयू बोलेगा
प्रोसेस आईडी मैं उस प्रोसेस की बात कर रहा हूं उस प्रोसेस का ये पेज नंबर मेरे को चाहिए और ये ऑफसेट चाहिए तो अब यहां पर
हम क्या करते हैं हम डायरेक्ट मान लीजिए मेन मेमोरी सर्च कर रहे हैं कि मेन मेमोरी के अंदर ये वाला प्रोसेस आईडी कहीं मैच हो
रहा है क्या अगर कंटेंट मैच करेंगे इंडेक्स नहीं कंटेंट मैच करें अगर वो प्रोसेस आईडी कहीं मैच हुआ तो उसका
जो करेस्पॉन्डिंग्ली 28 नंबर प मैच हुआ इसका मतलब मेरा जो एड्रेस है फिलहाल 28 है थोड़ा सोचना
पड़ेगा जब हम इंडेक्सिंग की पेज टेबल की बात करते थे तो पेज टेबल में हम सर्च करते थे इंडेक्स पे और वहां से रिटर्न होता था
मेरा कंटेंट यहां पर हम सर्च कर रहे हैं कंटेंट से कि ये एंट्री कहां पे है ये एंट्री कहां पे है जहां पे एंट्री मैच हो
रही है कौन से नंबर पे मैच हुई इस नंबर पे तो रिटर्न हो रहा है मेरा इंडेक्स उल्टा है ये तो गेम शानदार है ये भी बहुत अजीब
बात नहीं है लेकिन नॉर्मली हम इसे इंप्लीमेंट नहीं कर रहे होते और इस तरह से काम करता है क्यों क्योंकि कंटेंट सर्च
करना आसान काम है क्या ये सिस्टम को बहुत स्लो कर देगा और अगर सेट एसोसिएटिव फैशन में अ सारी एंट्री एक साथ सर्च करेंगे तो
सर्किट की कॉस्टिंग बहुत ज्यादा हो जाएगी तो आईडिया पढ़ने के लिए ठीक-ठाक है इनवर्टेड पेस टेबल बट प्रैक्टिकली इट इज
ऑफ नॉट दैट यूज यस नाउ कमिंग टू द नेक्स्ट पार्ट ऑफ द आइडिया अभी तक हम कंसंट्रेट कर रहे थे मेन मेमोरी पे अब हम कंसंट्रेट
करेंगे थोड़ा सा सेकेंडरी मेमोरी पे तो कैसे काम करेंगे क्या अंडरस्टैंडिंग होगी आइए एक-एक करके देखते हैं हेलो एवरीवन तो
अभी डिस्कशन स्टार्ट करेंगे वर्चुअल मेमोरी का एंड लॉजिकली इ इ इट्स एन एक्सटेंशन ऑफ द पुराना आईडिया मेन मेमोरी
का ही डिस्कशन करेंगे पहले बट उसको कुछ अलग तरीके से दो-तीन पॉइंट्स हम ऐड करते हैं जिस आईडिया को वर्चुअल मेमोरी कह के
बुलाते हैं मैं एक-एक करके बात करता हूं तो आई विल गो पॉइंट बाय पॉइंट अगेन टू इनेबल मल्टी प्रोग्रामिंग एंड ऑप्टिमाइज
मेमोरी मॉडर्न कंप्यूटर ऑफें यूज प्योर डिमांड पेजिंग टू कीप मल्टीपल प्रोसेस इन मेमोरी तो इसको मैं पहले समझाता हूं ध्यान
से देखिए ये तो हमने समझा कि सीपीयू है एंड देन कैश एंड देन मेन मेमोरी एंड देन सेकेंडरी है जो सबसे वैल्युएबल रिसोर्स है
यहां पे फिलहाल इस सब्जेक्ट में बात कर ें वो है मेन मेमोरी हर प्रोसेस चाहता है जो सेकेंडरी मेमोरी में है कि वो मेन मेमोरी
में आए लेकिन मेन मेमोरी हमारे पास बड़ी लिमिटेड है जैसे आजकल हम रम बोल रहे हो तो वो बड़ा लिमिटेड स्पेस है तो वहां हर किसी
को नहीं आने देंगे या कोई प्रोसेस है पूरी प्रोसेस को कंप्लीट लोड नहीं कर सकते हमें चाहिए कि प्रोसेस का सिर्फ वो हिस्सा लोड
करें जो रियलिटी में जरूरी है वही हमारे कार वाला एग्जांपल है ना तोब क्या है कि बहुत सारी कार है हमें लगा ये 10 कार बिकी
हम यू नो उनको शोरूम में लाके रख लि लेकिन बाद में मे भी हो सकता है हम लगे यार हमारा अंदाजा गलत था कोई और कार मिल रही
है प्योर डिमांड पेजिंग क्या कहता है जब तक सीपीयू खुद से ना बोल दे कि मेरे को यह वाला इंस्ट्रक्शन चाहिए या मेरे को यह
वाला पेज चाहिए तब तक हम अंदाजे पे या लोकैलिटी ऑफ रेफरेंस पर भी उस पेज को लोड नहीं करेंगे या गाड़ी वाले एग्जांपल बोलू
जब तक कस्टमर आके बोलना दे मेरे को यह वाली कार परचेस करनी है तब तक उस गाड़ी को शोरूम में नहीं लेके आएंगे ताकि शोरूम में
कभी भी एक्स्ट्रा कार नहीं रहे शोरूम का स्पेस बड़ा वैल्युएबल है वो उसी के लिए यूज होना चाहिए जिसकी सच में जरूरत है दिस
आइडिया इज नोन एज प्योर डिमांड पेजिंग सो अ मेमोरी मैनेजमेंट स्कीम वेयर प्रोसेस स्टार्टस विद नो पेज जब चालू करेगा कोई
पेज दे ही नहीं रहे उसको एंड द पेजेस आर ओन लोडेड व्हेन एक्सप्लीसिटली रिक्वायर्ड ड्यूरिंग एग्जीक्यूशन सिर्फ वही पेज लोड
होगा जिसकी सच में जरूरत है तो यानी क्या थोड़ा नुकसान तो होगा रन टाइम पे लेकिन एफिशिएंसी देखिए मेन मेमोरी का स्पेस एकदम
ऑप्टिमाइज रहेगा एक भी फालतू का पेज मेन मेमोरी में लोड नहीं होगा यस सो जीरो पेज के साथ आप स्टार्ट करेंगे इमीडिएट पेज
फॉल्ट होगा पेज फॉल्ट मतलब कोई ऐसा पेज जब मांग लिया जाए जो मेन मेमोरी में ना हो तो बोलते हैं पेज फॉल्ट हुआ जैसे ही पेज
फॉल्ट होगा उस पेज को लोड करेंगे एग्जीक्यूशन रिज्यूम करेंगे फिर से पेज फॉल्ट होगा फिर से यही प्रोसेस कंटिन्यू
करेंगे नए-नए पेज आते जाएंगे अब कुछ समय के बाद होगा क्या अगेन वो 5 6 10 जितने भी पेज जो एक्चुअली में रिक्वायर्ड है उस
प्रोसेस के लिए वो पेज सब के सब मेन मेमोरी में आ चुके होंगे और इसी तरह हमारा एग्जीक्यूशन कंटिन्यू चलेगा एग्जीक्यूशन
प्रोसीड विदाउट फेलियर फॉल्ट्स वंस ऑल नेसेसरी पेज इन द मेमोरी एंड यू नो दैट इज द की प्रिंसिपल कि हम एब्सलूट जो
रिक्वायर्ड आईडिया उसे लोड करें तो ये एक बात आपको समझ आ गई वर्चुअल मेमोरी ये जो शब्द है ना इसका मतलब समझाता हूं देखो इन
रियलिटी अब मान लीजिए मेरे पास रम है रम है फॉर एग्जांपल एक प्रैक्टिकल बात करता हूं 8gb की एंड लेट मी से हार्ड
डिस्क है 512 गगा बाट की मेक सेंस अब क्या मैं एक ऐसी प्रोसेस रन कर सकता हूं क्या जिसका साइज 50 गगा बाइट है अब मैं आपको
बोल रहा हूं प्रैक्टिकली जो चीज रन हो रही है रन तो मेन मेमोरी मे होरी है अगर मेन मेमोरी 8gb की है तो 50gb का प्रोसेस कैसे
रन होगा सर हो सकता है ना कैसे हम पूरा प्रोसेस क्यों लोड करेंगे कंटस लोकेशन की तरह इस 50gb का सिर्फ वही पोर्शन लोड कर
लेते हैं जो फिलहाल अभी यूज में है जब स्पेस कम पड़ेगा किसी पोर्शन को बाहर भेज देंगे उसकी तरह ले आएंगे यही कंसेप्ट
इजेंट इट आपके मेरे सिस्टम में भी तो यही हो रहा होता है हम बड़ी-बड़ी प्रोसेस रन कैसे कर पा रहे हैं क्योंकि जो डाटा चाहिए
पार्शियल लोडिंग कर र ना पूरा प्रोसेस लेके नहीं आ रहे प्रोसेस का जो हिस्सा चाहिए उसको लोड कर रहे एग्जीक्यूट कर र है
फिर बाहर भेज दे रहे हैं यही पूरा जो हमारा कांसेप्ट है यह कहलाता है वर्चुअल म तो वर्चुअलिटी क्या है वर्चुअलिटी है दैट
आई एम यूजिंग रियलिटी में 8gb बट इट सीम्स लाइक आई हैव अ कैपेसिटी ऑफ़ 512 गगा बाट क्योंकि सेकेंडरी में जो है मैं रन कर पा
रहा हूं और ये चमत्कार कैसे हो पा रहा है छोटे से स्पेस को बार-बार बार-बार घुमा के हो पा रहा है यस तो ये यू नो इवन दिस
प्योर डिमांड पेजिंग यही कारण है जिस वजह से वर्चुअल मेमोरी का वर्चुअल मेमोरी का जो एडवांटेज है वो आपको मिलता है सो
प्रोग्राम नो लंगर लोडेड बाय कांस्टेंट दैट द अमाउंट ऑफ फिजिकल मेमोरी दैट इज अवेलेबल अलाउ द एग्जीक्यूशन ऑफ अ प्रोसेस
दैट आर नॉट कंपलीटली इन द मेन पार्शियल लोडिंग अलाउड है नॉन कंटस लोडिंग अलाउड है इवन वो प्रोसेस जो एक साथ मेन मेमोरी में
आ भी नहीं सकते उनका भी एग्जीक्यूशन कर पाना यहां पॉसिबल है और एक टाइम पे मेन मेमोरी में आज आप देखते हो अपने
स्मार्टफोंस के अंदर 50-50 अभी भी चेक करोगे ना तो 50 प बैकग्राउंड में खुली है जबकि फोन लैग नहीं कर रहा क्यों कैसे हो
पा रहा है प्योर डिमांड पेजिंग की वजह से हो पा रहा है अगेन वर्चुअल मेमोरी डिसएडवांटेज अब ये पता नहीं मैं फिर वही
बात बोलूंगा इसको डिसएडवांटेज बोलूं कि नहीं बोलूं भाई थोड़ा अगर कहीं ओवरलोड कर दिया तो थ्रेशिंग होगी
थ्रेशिंग क्या होगी आगे डिटेल में डिस्कस करेंगे मतलब ऑप्टिमाइज करना है बट इतना कम स्पेस नहीं देना कि प्रोसेस बार-बार इसी
में लगा रहे कि किसको बाहर लाना है किसको अंदर रखना है जेनुइन स्पेस उसको मेन मेमोरी में मिलना चाहिए ताकि वेस्टेज भी
ना हो बट वो अच्छे से रन करे अब ये जो आईडिया मैं आपसे डिस्कस कर रहा हूं देखिए वही कहानी है यहां क्या करते हैं कैसे पता
लगेगा कौन पेज है कि नहीं है पेज टेबल तो हमारी पुरानी अंडरस्टैंडिंग है पेज टेबल में हम एक कॉलम ऐड करते हैं वैलिड इनवैलिड
बिट तो जहां वैलिड बिट है क्योंकि प्रॉब्लम क्या है ना आप बोलोगे सर जहां एंट्री नहीं वो इनवैलिड है अबे यू नो
कंप्यूटर के अंदर मेमोरी में गार्बेज वैल्यू रहता है कुछ नहीं देख के समझ आता क्या वैलिड है क्या इनवैलिड है तो वैलिड
इनवैलिड बिट है वैलिड मान लीजिए वन है इनवैलिड मान लीजिए जीरो है ट्रू फॉल्स मान लेते बाइनरी नेचर का तो जहां-जहां इनवैलिड
वैल्यू है इसका मतलब यह पेज अभी मेन मेमोरी में नहीं है पेज टेबल अपनी जगह सेम है और जहां-जहां वैलिड वैल्यू इसका मतलब
यह पेज है तो पेज नंबर जीरो आई शुड से पेज नंबर टू एंड पेज नंबर फाइव पेज नंबर जीरो कहां पे है फ्रेम नंबर फोर में है कौन है
जीरो जीरो इज ए फ्रेम नंबर फोर मेन मेमोरी का हां नजर आ गया पेज नंबर टू इज सी फ्रेम नंबर सिक्स में है हां सिक्स में सी मिल
गया एंड पेज नंबर नाइन ये फ्रेम है ना पेज नंबर फाइव नाइन आप देखेंगे एफ ये नाइन में आपको एफ मिल गया सो दैट इज हाउ हम इसे
मैनेज कर रहे हैं अगेन मैं आपको क्या समझा रहा हूं क्या पेज फॉल्ट क्या होता है जब आप किसी ऐसे मान लीजिए प्रोसेस ने बोला कि
मेरे को ना पेज नंबर फोर चाहिए अभी पेज नंबर फोर है नहीं सर इसको लोड करना पड़ेगा सेकेंडरी में सब है इधर नहीं इसको लोड
करके लाना पड़ेगा जब प्रोसेस किसी ऐसे पेज को मान ले जो मेन मेमोरी में नहीं है इस सिनेरियो को हम बोलते पेज फॉल्ट हो गया
आगे बढ़ते हैं पेज फॉल्ट हैंडल कैसे करेंगे पूरा सिनेरियो डायग्राम के थ्रू समझाने की कोशिश करिए देखिए एक बार किसी
प्रोसेस का एग्जीक्यूशन चल रहा था अचानक से एक ऐसा पेज नंबर वन देखिए गैल्विन की इमेज यूज कर रहा हूं एक ऐसा पेज रेफर किया
गया जहां पर इनवैलिड है प्रॉब्लम हो गई अब नया पेज कौन लेके आएगा सर यह काम ऑपरेटिंग सिस्टम का है तो एग्जीक्यूशन चला गया
सिस्टम के हाथ में सिस्टम कॉल हुआ अब वह जाएगा ओस अपने हाथ में कंट्रोल लेगा और जाके बैकअप स्टोर में चेक करेगा कि यह पेज
लोड करना है यस अब यह जो पेज होगा अब दो सिनेरियो है या तो मेन मेमोरी में जगह होगी या तो मेन मेमोरी में जगह नहीं होगी
फिलहाल हम मान लेते हैं मेन मेमोरी खाली थी जगह थी उस पेज को हमने लोड किया यस लोड करने के बाद इस बिट को वैलिड करेंगे यहां
पे जिस जो भी फ्रेम नंबर मिला होगा उसको यहां पे रिराइज करेंगे और एग्जीक्यूशन कंटिन्यू करेंगे दैट इज हाउ वी एक्चुअली
सर्विस अ पेज फॉल्ट तो बेसिकली हमें ये पूरा करना पड़ा दूसरा सिनेरियो क्या हो सकता था जो पेज फॉल्ट हुआ है लेके तो आना
ही है उसमें कोई ऑप्शन नहीं है बट प्रॉब्लम ये हो सकती थी अगर मेन मेमोरी में जगह ही ना होती तो क्या करते तो फिर
यहां से किसी दूसरे फ्रेम को पकड़ के बाहर निकालना पड़ता हां कि ना बोलो किसी फ्रेम को पकड़ के बाहर निकालते उसकी जगह इसको
रिप्लेस करते और तब एग्जीक्यूशन कंटिन्यू होता बाहर निकालना थोड़ा सा ट्रिकी प्रोसेस है बाद में उसमें बात करेंगे दिस
इज कॉल्ड पेज रिप्लेसमेंट एल्गोरिथम किसको बाहर निकाल ले अगर गलती से किसी ऐसे पेज को बाहर निकाल दिया जो भी इस्तेमाल में है
तो दो मिनट के बाद फिर से पेज फॉल्ट होगा तो बड़ा ध्यान लगा के सोचना पड़ता है किसको बाहर निकालने किसको बाहर ना निकाल
तो यह भी लॉन्ग रन में एक बड़ा इंपॉर्टेंट आईडिया काम करता है और इसमें एक आईडिया हम जो यूज करते हैं वो है मॉडिफाइड बिट का
आईडिया वो भी समझाता हूं सारा जो नोट्स है वो आप साथ साथ देखते चल रहे हैं मॉडिफाइड बिट का आईडिया क्या है देखिए अगर कोई पेज
ऐसा है जो हमने मेन मेमोरी में चेंज किया है उसमें कुछ चेंज है तो उसको मुझे बाहर वापस से मेन मेमोरी में सेकेंडरी मेमोरी
में स्टोर करना पड़ेगा लेकिन अगर मैंने कोई चेंज नहीं किया एक पेज लोड किया तो उसमें कोई चेंज नहीं किया तो क्या मुझे
उसे दोबारा से सेकेंडरी में लेके जाना पड़ेगा विक्टिम को नहीं क्योंकि सेकेंडरी से मैं कॉपी पेस्ट करके लाया हूं कट पेस्ट
करके थोड़ी लाया हूं भाई मान लीजिए i की वैल्यू फाइव थी ये वैल्यू मैंने मेन मेमोरी में कॉपी कर ली अगर वैल्यू फाइव ही
है तो बस ओवरराइट कर दो इसको प्रॉब्लम क्या है हां अगर आपने एग्जीक्यूशन के दौरान इसमें कुछ चेंज कर दिया इसको सिक्स
किया तो जरूर वापस लेके जाइए बताने के लिए कि वो वैल्यू सिक्स हो गया इजन इट तो रिप्लेसमेंट में जब विक्टिम सेलेक्ट किया
जाएगा अगर विक्टिम मॉडिफाइड है है ना जिसको बाहर निकालना है अगर मॉडिफाइड है तो उसको दोबारा से सेकेंडरी में अपडेट करना
पड़ेगा बट अगर विक्टिम मॉडिफाइड नहीं है तो आई थिंक आप बात समझ रहे हो उसको अपडेट करने की जरूरत नहीं है उसको डिस्कार्ड कर
दो तो अगेन एक और बिट लगा लेते हैं यहां कहीं मेंशन है नहीं एक और बिट लगा लेते हैं मान लीजिए पेस्ट टेबल है ना एक तो
वैलिड इनवैलिड बिट है इसको बोलते हैं आमतौर पे डर्टी बिट एक और बिट लगा लेते हैं डर्टी बिट या मॉडिफाइड बिट तो विक्टिम
सेलेक्ट करते हुए ये भी देखना है कि अगर हमें कोई ऐसा विक्टिम मिल जाए जो डर्टी नहीं है तो वो पेज रिप्लेसमेंट जल्दी होता
है फास्ट होता है क्योंकि उसमें आपको दोबारा से सेकेंडरी में स्टोर नहीं कराना पड़ेगा बट अगर बिट डर्टी है तो फिर तो
स्टोर करा नहीं है उसका कोई ऑप्शन नहीं होता फेयर इनफ तो यह मडि फाइड बड डायट बड वाली बात आप समझ गए प्रोसेस मैनेजमेंट आप
समझ गए अगेन अगर यहां से एवरेज टाइम निकालना हो तो कैसे करेंगे वही बेसिक फार्मूला जो मेमोरी में हम पहले यूज करते
थे फॉर एग्जांपल लेट मी से कि पेज फॉल्ट बहुत ज्यादा नहीं होगा पेज फॉल्ट होने का चांस है 20 पर फॉर एग्जांपल तो पहले मैं
क्या बोलता हूं इफेक्टिव टाइम कैसे निकालेंगे 20 पर केस में पेज फॉल्ट होगा तो 8 80 पर
केस में पेज फॉल्ट नहीं होगा और मेन मेमोरी का जो एवरेज एक्सेस टाइम है वही टाइम हमारा भी होगा ले लेकिन कुछ परसेंट
केस में पेज फॉल्ट होगा जैसे मान लीजिए 20 पर केस में हुआ उस केस में पेज फॉल्ट सर्विस टाइम पूरा जो भी है पेज को बाहर
निकालना आइडेंटिफिकेशन निकाल सकते हैं अब यहां पर सर जो सबसे
इंपॉर्टेंट जिसम क्वेश्चन आता है वो है पेज प्लेसमेंट एल्गोरिथम ये वही सब दिखाया ज्यादातर केस में मेन मेमोरी खाली
नहीं होगी और अगर पेज फॉल्ट होर आप लोड करेंगे तो आपको किसी ऐसे पेज को बाहर करना पड़ेगा जो काइंड ऑफ जरूरी है बट फिर भी उन
सब में से किसको विक्टिम चूज करें और ये बड़ा इंपोर्टेंट है लगभग हर साल इस पे क्वेश्चन मिलेगा ही मिलेगा तो हाउ टू चूज
अ यू नो अ विक्टिम बहुत सारे अप्रोचेबल अप्रोच है जो हर अप्रोच में हम सबसे पहले पढ़ रहे हैं दैट इज फर्स्ट इन
फर्स्ट आउट तो मैं रन टाइम तो सॉल्व नहीं कर रहा एक स्क्रीनशॉट लेके आया हूं आपको बात समझाता हूं हाउ ड हाउ डज दिस वर्क
आईडिया क्या है पहली पॉलिसी है तो बहुत ज्यादा दिमाग लगाएंगे नहीं भाई उसको बाहर कर दो जो बहुत समय से इस्तेमाल नहीं हुआ
है सिंपल एज दैट उसको बाहर करेंगे जो सबसे लंबे समय से इस्तेमाल नहीं हुआ अगर ऐसा है चला के देखते अब देखिए जब स्टार्टिंग में
लोड किया प्योर डिमांड पेजिंग है प्रोसेस खाली रहा होगा जैसे मैंने पहले बोला सबसे पहले आया सेवन ये स्ट्रिंग क्या बता रहा
है ये बता रहा है कौन-कौन से पेज चाहिए सेवन आया लोड कर लिया पेज फॉल्ट है यह जो बॉक्स मैं बनाऊंगा तब बनाऊंगा जब
पेज फॉल्ट होगा जीरो आया लोड किया पेज फॉल्ट है वन आया लोड किया पेज फॉल्ट है अभी तक रिप्लेसमेंट की जरूरत नहीं थी तो
बेसिकली यू डोंट नीड एन एल्गोरिथम यहां सब भर गया अब टू आया बोलो बाहर कौन जाएगा तो आईडिया क्या है वो बाहर जाएगा जो सबसे
लंबे समय से इस्तेमाल नहीं हुआ आई एम सॉरी आई एम सॉरी जो अभी तो एफसीएफएस पही है ना फर्स्ट इन फर्स्ट जो सबसे पहले आया था
सबसे पहले सेवन आया था सर हो सकता है सेवन यूज में हो इस बात से मतलब नहीं है जो पहले आया था जाएगा ये पॉलिसी है ठीक है तो
सेवन को बाहर करा देखिए उसकी जगह टू आ गया जीरो पे पेज फॉल्ट हुआ क्या नहीं जीरो तो है मेरे पास अब थ पे पेज फॉल्ट हुआ अब
बताओ बाहर कौन जाएगा फिलहाल देखिए सबसे सीनियर कौन है टू तो अभी आया है वन दो बार है जीरो सबसे सीनियर है हां जीरो को बाहर
भेज दो तो जीरो को बाहर भेजा उसकी जगह आया थ्री और सिर मुंडाते ही ओले पड़े देखिए प्रॉब्लम क्या है जिसको बाहर भेजा अगली
बार में वही यूज हो गया अब कौन बाहर जाएगा फिर देख लीजिए थ और वन में सबसे सीनियर कौन वन सबसे सीनियर है तो वन विल विल बिकम
विक्टिम और वन की जगह आ जाएगा जीरो और यही पॉलिसी आगे तक चलती जाएगी बताइए समझ आ रहा है क्या एक बार पॉज करके आगे सॉल्व करके
देख सकते हैं तो हु विल गो आउट हु विल बिकम विक्टिम जो सबसे लंबे समय से अंदर है जो फर्स्ट इन हुआ था वही यहां पर विक्टिम
बनेगा दैट इज व्हाट दिस पॉलिसी सेज है ना इसका एक इतना इंपॉर्टेंट टर्म है जो बार-बार पूछा जाता है मैंने उसका अलग से
केस नहीं बनाया बट क्या लॉजिक है लॉजिक समझिए एक टर्म है जिसे बोलते हैं बिलेडी एनमल मु बोलो क्या बोलते हैं बिलेडी एनमल
नाउ व्हाट इज दिस बिलेडी एनमल इन जनरल अगर हम किसी प्रोसेस के पास नंबर ऑफ फ्रेम्स बढ़ाएंगे इफ वी
इंक्रीज द नंबर ऑफ फ्रेम तो ये इन जनरल एक्सपेक्टेशन है कि जो नंबर ऑफ पेज फॉल्ट्स होंगे क्या होंगे जो नंबर ऑफ पेज
फॉल्ट्स होंगे दैट मस्ट गो डाउन भाई जितने ज्यादा पेज होंगे उतना अच्छा काम चलेगा बार-बार रिप्लेस नहीं करना पड़ेगा बट दिस
फीफो इज एन एक्सेप्शन फॉर सर्टेन स्ट्रिंग्स अच्छा मैं ये नहीं बोल रहा हूं हमेशा ऐसा हो बट कभी-कभी ऐसा हो सकता है
फॉर सर्टेन स्ट्रिंग्स इवन नंबर ऑफ फ्रेम जब हम बढ़ाएं दे द नंबर ऑफ पेज फॉल्ट्स मे गो अप कभी-कभी ऐसा हो सकता है इस इस
प्रोसेस को एक सिनेरियो को इस एनमल इस समस्या को बोलते हैं बी लेडीज एनमल ये यूनिवर्सिटी एग्जाम में कॉम्पिटेटिव
एग्जाम में गेटनेट सब जगह बात बार-बार पूछी जाती है इसको मत भूलिए याद रखेंगे तो फीफो की फंडामेंटल पॉलिसी आपको समझ आ गई
है विदाउट अ डाउट और यह आसान है बहुत बढ़िया है लेकिन एफिशिएंट नहीं है और बिलेडी एनमल सफर करता है इसकी प्रॉब्लम है
गोइंग फॉरवर्ड ऑप्टिमल ये मान के चलिए जैसे सीपीयू शेड्यूलिंग में हमने बस टाइम वाला यूज़
किया था ना शॉर्टेस्ट शॉर्टेस्ट जॉब फर्स्ट ये वही वाली अप्रोच है यहां क्या करते हैं सर हमारे अंदर अजीब ताकतें आ गई
हम फ्यूचर देखते हैं और उस पेज को बाहर करते हैं जो फ्यूचर में यूज़ ना हो रहा हो उदाहरण के लिए पहले तीन पेज फॉल्ट तो होने
ही है जब पहली बार एक्सेस कर रहा हूं अब जब टू अंदर आएगा तो बाहर कौन जाएगा है ना तो यहां से फ्यूचर देखना शुरू करो जीरो
यूज हो रहा है जीरो इंपॉर्टेंट है फिर देखो टू अ यहां पे थे ना जीरो यूज हो रहा है जीरो इंपॉर्टेंट है अब टू देखना है तो
सेन और वन में कौन बचेगा जो पहले आ जाएगा वन पहले आ रहा है यानी कि वन भी इंपॉर्टेंट है तो कौन बाहर जाएगा सेवन
बाहर जाएगा टू आ जाएगा सेवन की जगह जीरो पे पेज फॉल्ट नहीं होगा अब देखो यहां थ्री पे फिर पेज फॉल्ट होगा अब देखो थ्री किसकी
जगह खाएगा फिर आगे चलो यहां से आगे चलोगे जीरो आया जीरो इंपॉर्टेंट है फिर आगे चलो देखते हैं टू और वन में टू आ गया टू पहले
इंपॉर्टेंट है वन अभी नहीं आया तो वन विक्टिम बना और थ्री ने वन की पोजीशन ले ली रो पे फिर पेज फॉल्ट नहीं होगा फिर
देखो फोर आना है किसकी जगह लेगा फिर आगे चलो फोर से टू आया इंपॉर्टेंट है थ्री आया इंपॉर्टेंट है जीरो भी आ रहा होगा लेकिन
पहले जो आ रहा है वो इंपॉर्टेंट है तो फोर किसको रिप्लेस करेगा जीरो को एंड दैट इज हाउ यू गो फॉरवर्ड दिस इज अ प्योर ग्रीडी
अप्रोच अब इससे ग्रीडी क्या होगा यार मैं जा रहा हूं मैं फ्यूचर को देख रहा हूं और फ्यूचर में जो सबसे लंबे समय तक इस्तेमाल
नहीं हो रहा उसको मैं बाहर कर रहा हूं सो दिस आईडिया दिस एनटायर लॉजिक इज कॉल्ड ऑप्टिमल रिप्लेसमेंट ओबवियसली क्योंकि हम
प्योर ग्रीडी है इन द लंगर रन क्या यहां पर हमें मिनिमम नंबर ऑफ पेज फॉल्ट्स मिलते हैं जी हां तो दिस प्रोसेस विल गिव मिनिमम
नंबर ऑफ पेज फॉल्ट्स मतलब कोई इसकी बराबरी कर सकता ओबवियसली बट इसको बीट नहीं कर सकता प्रॉब्लम क्या है अगर सबसे अच्छा है
यह तो सभी इसको यूज़ करें इंप्लीमेंटेबल कहां है फ्यूचर रेफरेंस ट्रिंग किसको पता है तो यह एल्गोरिथम सिर्फ एक केस स्टडी की
तरह काम कर सकता है आपको एक रास्ता दिखा सकता है कि यार अगर ऑप्टिमल इतना पेज फॉल्ड कर रहा है तो इतना तो होना ही था
उसके बाद आप देखो उसके क्लोज तक कैसे जा सकते हो यस अप्रोच मैंने आपको बताया लॉजिक मैंने आपको बताया प्रॉब्लम इसकी बता दी
इंप्लीमेंटेबल नहीं है इंप्लीमेंटेबल फिर क्या है जो अच्छा भी हो वो है एल आरयू या लीस्ट रिसेंटली यूज सबसे ज्यादा क्वेश्चन
एग्जाम में कोई पूछा जाता है तो यह पूछा जाता है इसकी कहानी क्या है सर जिसका फ्यूचर नहीं देख सकते बट फ्यूचर प्रिडिक्ट
करना चाहते उसकी हिस्ट्री देख लीजिए यह मैकेनिज्म काम करता है क्या बोलना चाह रहा हूं सेवन आया सेवन के बाद जीरो आया वन आया
यहां तक तो इंपॉर्टेंट है अब टू आया कौन बाहर जाएगा यहां से उल्टा चलना शुरू करिए वन यूज हुआ है लोकैलिटी ऑफ रेफरेंस
इंपॉर्टेंट है रो यूज हुआ लोकैलिटी ऑफ रेफरेंस इंपोर्टेंट है कौन नहीं यूज हुआ सेवन सेवन की जगह आ जाएगा टू जीरो पे पेज
फॉल्ट हुआ यस नहीं नहीं हुआ थ्री पे आ जा थ्री किसको बाहर करेगा फिर देखिए यहां से उल्टा चलिए जीरो यूज हुआ इंपॉर्टेंट है टू
यूज हुआ इंपॉर्टेंट है कौन बाहर होगा वन अगर फीफो होता तो रो को बाहर किया होता बट क्योंकि रो दोबारा यूज हुआ उसने बोला बेटा
टा मैं इंपोर्टेंट हूं मुझे मत बाहर करना तो थ्री किसको रिप्लेस करेगा वन को रिप्लेस करेगा जीरो पे फिर पेज फॉल्ट नहीं
हुआ फिर फोर पे हुआ फिर यहां से उल्टा चलिए जहां भी बज फॉल्ट होगा उल्टा रो बार-बार यूज़ हो रहा है इंपॉर्टेंट है
थ्री यूज़ हुआ इंपॉर्टेंट है टू बहुत समय से इंपॉर्टेंट नहीं हुआ लगता है टू की फिलहाल जरूरत नहीं है फोर किसको रिप्लेस
करेगा 4 टू को रिप्लेस करेगा जब इस तरह से हम आगे बढ़ते जाएं जब भी पेज फॉल्ट है प्रीवियस हिस्ट्री देखे और उस बेस पे
डिसाइड करें तो ये जो एल्गोरिथम है ये एल आरयू है फीफो से इन जनरल इसकी परफॉर्मेंस बहुत बढ़िया है ये इंप्लीमेंटेबल भी है और
काफी हद तक य ऑप्टिमल के क्लोज जा रहा होता है तो एलआरओ आई थिंक इज वन ऑफ द मोस्ट पॉपुलर एल्गोरिथम जो इस्तेमाल होता
है इसके अंदर बिलेडी या वो सब कोई प्रॉब्लम नहीं है यस तो यह हमारी कहानी थी किसकी
अ रिप्लेसमेंट की अब थोड़ा सा एक आईडिया आपको समझा देता हूं थ्रेशिंग का इसमें मैंने पूरा पॉइंट लिखा है थ्रेशिंग की
क्या कहानी है यह तो आपने समझा कि कितने-कितने फ्रेम देने है और कैसे-कैसे इस्तेमाल होता है अब आईडिया यह है कि अ
कभी-कभी क्या हो सकता है मैं आपको एग्जांपल से समझाता हूं मैंने शेड्यूलर वाली पूरी बात लिखी है देखिए जैसे-जैसे
मेन मेमोरी में डिग्री ऑफ मल्टी प्रोग्रामिंग बढ़ती है नंबर ऑफ प्रोसेस बढ़ेंगे ऑब् वियस सीपीयू यूटिलाइजेशन
बढ़ेगा है ना लेकिन होगा क्या एक लेवल पे जाके ना बॉटल नेक करेगा बॉटल नेक करेगा मतलब अभी सीपीयू तो यूटिलाइज हो रहा है
लेकिन पॉइंट यह कि मेन मेमोरी बहुत भर चुका होगा बहुत सारी प्रोसेस आ गई है अगर उससे थोड़ा भी ज्यादा मैं प्रोसेस बढ़ाने
की कोशिश कर करूंगा तो सीपीयू ठीक है लेकिन प्रोसेसेस के पास जगह बहुत कम हो जाएगी एक प्रोसेस है मान लो जिसे जेनुइनली
सेवन फ्रेम्स की जरूरत है अभी उसे पांच ही मिल पा रहे तो क्या होगा बार-बार पेज फॉल्ट होगा पेज फॉल्ट होगा तो ज्यादा समय
सीपीयू एग्जीक्यूशन में खर्चा करेगा या इनपुट आउटपुट में किसी को बाहर लेके आओ फिर किसी को अंदर लेके आओ यह कहानी चलेगी
और इसकी वजह से अब हमारा सीपी यूटिलाइजेशन बढ़ने के बजाय सर कम होने लगेगा जैसे ही सीपी यूटिलाइजेशन कम होगा लॉन्ग टर्म
शेड्यूलर जो हमने सीबी शेड्यूलिंग में पढ़ा था उसको क्या लगेगा उसको लगेगा यार कोई प्रॉब्लम है लगता है मैं प्रॉपर तरह
से प्रोसेस पुश नहीं कर रहा वो डिग्री ऑफ मल्टी प्रोग्रामिंग और बढ़ाएगा क्या और प्रोसेस पुश करो लगता है सीपीयू खाली है
भाई वहां प्रोसेस पहले ज्यादा रखी भीड़ हो गई है अब और प्रोसेस पुश होंगी तो बोलो क्या होगा भीड़ और ज्यादा होगी इसके फ्रेम
पांच के बजाय दो रह जाएंगे अब इसे दो में मैनेज करना चाहिए इसको साथ बार-बार पेज फॉल्ट होगा सीबी यूटिलाइजेशन ड्रास्ट्रिंग
जैसे ही नीचे गिरेगा शेड्यूलर को लगा ओ माय गॉड लगता है मैं मैनेज कर ही नहीं पा रहा और प्रोसेस पुश करो एक लेवल के बाद
इसके पास एक फ्रेम बचेगा और अब ना आप कुछ करोगे ना यह कुछ करेगा सब बैठ के एक दूसरे की शक्ल देखेंगे क्योंकि बार-बार बार-बार
पेज फॉल्ट हो रहा होगा सो दिस दिस यू नो ड्रॉपिंग ऑफ परफॉर्मेंस इज नोन एज थ्रेशिंग की सिस्टम थ्रश हो गया तो ये
ऑप्टिमल नंबर हमारे पास होना चाहिए इसके आगे जाएंगे तो परफॉर्मेंस दोबारा से गिरने लगती है ये पूरा कांसेप्ट थ्रेशिंग कहलाता
है कैसे पता लगाए अब मैंने तो आपको बोल दिया ये ऑप्टिमल नंबर ऑप्टिमल नंबर मिलेगा कैसे वो मिलेगा एक वर्किंग सेट स्ट्रेटेजी
लॉजिक क्या है आप प्रोसेस से पूछो मत कितना चाहिए उसका बिहेवियर देखो कितना चाहिए बच्चे घर में कोई स्वादिष्ट चीज बनी
रसगुल्ले बने बच्चे से पूछा कितने रसगुल्ले चाहिए बोल रहा है 100 खाऊंगा मैं 100 रसगुल्ले खाऊंगा खा नहीं पाएगा मैं
पता बट नहीं दो तो रो रहा है क्या करें कैसे पता लगाए कितना खाएगा उसका प्रीवियस बिहेवियर देखो तो यहां पर हम क्या करते
हैं फॉर एग्जांपल एक विंडो बनाते हैं कि लेट मी से मैं लास्ट के 10 एक्सेस देखूंगा तुम्हारे कि लास्ट 10 तुमने कितने पेज
रेफर किए उसमें मैं देख रहा हूं यूनिक पेज तो पांच ही है सात नंबर कई बार रेफर किया पांच नंबर किया तो आपका डिमांड पांच है 10
से कितने एग्जैक्ट पांच है थोड़ी आगे गए फिर मैंने देखा लास्ट एंड रेफर कितने हैं उसमें तो दो ही पेज समझ आए तो हम क्या
करते हैं हर थोड़े-थोड़े समय के बाद देखते हैं एक यू नो एक विंडो बना लेते हैं ऑफ साइज डेल्टा देखते हैं इस विंडो में कितने
डिस्टिंक्ट पेज अभी इस्तेमाल कर रहा है क्योंकि जैसे-जैसे एग्जीक्यूशन चलेगा पैटर्न चेंज हो सकता है तो कितने
डिस्टिंक्ट पेज इसने इस्तेमाल कि है उससे हमें पता लगता है इसकी एग्जैक्ट डिमांड क्या है और फिर उस प्रोसेस को एगजैक्टली
उतनी ही पेज हम एलोकेट करते हैं ये जो पूरा कांसेप्ट है इसको हम बोलते हैं वर्किंग सेट स्ट्रेटेजी है ना तो इसके
थ्रू हालांकि दिस इज नॉट दैट इंपॉर्टेंट बट पूरा गेम डेल्टा की साइज पे भी डिपेंड करता है अब अगर आप उसके लास्ट दो ही
एक्सेस देखोगे तो आपको सही डिमांड नहीं पता लगेगी आप उसके लास्ट 200 एक्सेस देखोगे तो भी उसकी सही डिमांड नहीं पता
लगेगी इजेंट इट तो सही डिमांड हमें पता लगे उसके लिए डेल्टा का साइज बड़ा एप्रोप्रियेट लेना है उससे आपको डिमांड
पता लगेगी जितना डिमांड चाहिए उतनी फ्रेम एलोकेट करो तो कभी थ्रेशिंग की सिनेरियो भी नहीं होगा और जो सीपीयू की परफॉर्मेंस
है वो भी आपको हमेशा ऑप्टिमल मिलेगी यस तो ये हमारा हो गया वर्किंग सेट स्ट्रेटेजी फेयर इनफ सो अब आगे बात करते हैं डिस
शेड्यूलिंग के बारे में मान के चलिए कि अभी मेन मेमोरी का मैनेजमेंट काफी हो गया फिजिकल आर्किटेक्चर डिस्क का क्या है फाइल
मैनेजमेंट के क्या इश्यूज है अब जरा उन पॉइंट पर कंसंट्रेट करेंगे तो अभी बात करते हैं सेकेंडरी मेमोरी और सेकेंडरी
मेमोरी के भी हार्डवे ऑर्गेनाइजेशन जो है डिस्क के बारे में तो सबसे पहले समझते हैं कि सेकेंडरी मेमोरी जो आमतौर प हम बात
करते हैं हार्ड डिस्क बात करते हैं वो दिखती कैसी है अंदर से कैसे दिखती है तो तो ये तो एग्जैक्ट रियलिस्टिक डायग्राम है
अगर आप में से कुछ लोग के पास होगी ही एक्सटर्नल हार्ड डिस्क होती है तो दिस इज द सिनेरियो देर यू कैन सी क्या सिस्टम है
यहां पर हमारे पास बहुत सारे सर्कुलर डिस्क होते हैं जैसे पहले ऑप्टिकल डिस्क आती थी अभी तो काइंड ऑफ मार्केट्स आउट हो
गई है तो इनके दोनों तरफ दीज आर नॉट ऑप्टिकल डि दीज आर मैग्नेटिक डिस्क है ना तो इनके ऊपर और नीचे दोनों सरफेस पे हम
लिख सकते हैं और यहां पे आप देख रहे हैं पूरी असेंबली है हेडर की ऊपर नीचे ऊपर नीचे यानी कि यहां पे चार डिस्क मेरे को
नजर आ रही है तो आठ एडर यहां पर होंगे मैग्नेटिक डिस्क कुछ अगर इंपॉर्टेंट पॉइंट बोले मैग्नेटिक डिस्क सर्व एज अ मेन
सेकेंडरी स्टोरेज यस तो मैग्नेटिक डिस्क सर्व एज द मेन सेकेंडरी स्टोरेज इन कंप्यूटर ईच
डिस्क हैज अ फ्लैट सर्कुलर प्लैटर विद मैग्नेटिक सरफेस ऑन द डेटा स्टोरेज आमतौर पे ये जो पूरा सरफेस इसको प्लैटर कहते हैं
है ना एक पूरी असेंबली हमारे पास है रीड राइट हेडर होवर्स ओवर द सरफेस मूविंग इन सिंकन ऑन द डिस्क आर्म प्लेटर हैव ट्रैक्स
डिवाइडेड इनटू सेक्टर और यह मैं थोड़ा सा एक बार बता देता हूं हालांकि मुझे लगता है ज्यादातर लोग को पता होता है तो ये जो
सर्कुलर डिस्क है यह कॉनस सर्कल्स में डिवाइड होती है एंड दस कंसेंट सर्किल आर नोन एस ट्रैक्स जैसे यहां पर भी आपको नजर
आ रहा है फिर यह जो ट्रैक्स है यह फरदर डिवाइडेड होते हैं इस तरह से और ये जो एक सेक्शन है मान लीजिए अ सेक्टर का दिस इज द
सेक्टर एंड दिस इज द ट्रैक इसको हम बोलते हैं सेक्टर है ना तो ये एक सेक्टर हमारे पास होता है क्या नॉर्मल एक पॉइंट लिख रहे
हैं डिस्क स्पिन एट अ रेट ऑफ 60 टू 250 रोटेशंस पर सेकंड यूजुअली वेरी कर सकते हैं डिपेंडिंग ऑन द इंप्लीमेंटेशन कॉमनली
नोटे आरपीएम इज लाइक फ 400 टू 15000 लगभग 5000 से 15000 रिवोल्यूशन पर मिनट आरपीएम मींस रिवोल्यूशन पर मिनट तो इतने स्पीड से
डिस घूम रही होती है अब हमें इसके बारे में क्या करना है तो सबसे पहले बात बता देता हूं हमें ओबवियसली रीड राइट ऑपरेशन
करना होगा जो करने में कुछ टाइम लगेगा तो कितना टाइम लगेगा और कौन-कौन से फैक्टर्स कौन-कौन से प्रॉब्लम है जो हमें सॉल्व
करने होते हैं एक-एक बार करके बात करता हूं तो देखिए जैसे मैं लिख रहा हूं टोटल ट्रांसफर टाइम जो है वो तीन फैक्टर्स पर
मिलके बना है कौन-कौन सा आप देख सकते हैं वन इज सीक टाइम अनदर इज रोटेशनल लेटेंसी एंड वन ऑफ देम इज अ ट्रांसफर टाइम नाउ लेट
मी गो वन बाय वन पहले बात करता हूं सीक टाइम के बारे में तो देखो ये जैसा आप देख भी रहे हैं ना हेडर्स की असेंबली कैसे मूव
करती है तो मान लीजिए किसी ने बोला कि यह जो ट्रैक है यहां से मुझे री ड्राइट ऑपरेशन करना है तो जैसा आप देख रहे हैं
हेडर को फिजिकली मूव करके इस डिजायर्ड ट्रैक तक हमें पहुंचाना पड़ेगा इजेंट इट तो जो टाइम खर्च होगा हेडर को मूव करके इस
डिजायर्ड ट्रैक तक पहुंचाने में दिस टाइम इज नोन एज सीक टाइम तो इसको हम क्या बोल रहे थे सीक टाइम एक बार पढ़ें क्या लिखा
हुआ है इट इज द टाइम टेकन बाय रीड राइट हेडर टू रीज द करेक्ट ट्रैक ऑलवेज गिवन इन द क्वेश्चन ऐसा क्यों लिख रहा हूं देखो
फिजिकली मूव करने में कितना समय लगेगा यह हम कैलकुलेट कैसे करेंगे फिजिकली कितना मूवमेंट होगा कितना फ्लक्स है कितना
मैग्नेटिक फील्ड है कितना एक्सीलरेशन है कितना स्पीड फिजिक्स का क्वेश्चन बन जाएगा हम फिजिक्स के स्टूडेंट तो है नहीं तो
उनको भी बात पता है तो आइर दे से यू जस्ट इग्नोर द सीक टाइम या फिर वो पहले से देर कंसीडर सीक टाइम इज 4 मि सेकंड और 8 मिली
सेकंड समथिंग लाइक दिस बट यह जो हमारा टाइम है दिस इज़ द सी टाइम सेकंड हमारे पास आ जाता है रोटेशनल लेटेंसी ना व्हाट
इज रोटेशनल लेटेंसी जैसे आप देख रहे हैं डिस्क एक स्पीड से रोटेट कर रही है है ना अब मान लीजिए हमें जो सेक्टर पढ़ना है वह
इधर कहीं पर लिखा हुआ है भले ही हेडर मूव करने के बाद हम करेक्ट ट्रैक पे हो बट आप ये बात समझ रहे हैं कुछ
टाइम लगेगा रोटेट होने के बाद इसको इधर तक आने में यस और नो और यह जो टाइम लगेगा इसको हम बोलते हैं रोटेशनल लेटेंसी यानी
के जब ट्रैक जब हेडर हमारा डिजायर्ड ट्रैक पर पहुंच जाए तो कितना टाइम लगेगा एग्जैक्ट सेक्टर तक पहुंचने में दिस इज
नोन एज रोटेशनल लेटेंसी अब रोटेशनल लेटेंसी की प्रॉब्लम क्या है देखिए ये रैंडम है अगर हमारी किस्मत बहुत अच्छी है
तो सोचिए ऐसा हो सकता है क्या द मूमेंट यू रीच अ डिजायर्ड सेक्टर जैसे ही आप वहां पे पहुंचे डिजायर्ड ट्रैक में बोलूंगा जिस
सेक्टर से आपको रीड राइट करना है एग्जैक्ट वो सेक्टर आपके पास आ जाए हो सकता है उस केस में जो आपकी रोटेशनल लेटेंसी की
वैल्यू होगी सर वो हो जाएगी जीरो मानते हो इस बात को दूसरी प्रॉब्लम समझो ऐसा भी हो सकता है जहां पे आपको रीड राइट करना है वो
पोर्शन जस्ट अभी वहां से निकला हो हां हो सकता है और वो जबी वहां से निकला है तो फिर एक पूरा कंप्लीट रेवोल्यूशन वन
कंप्लीट रेवोल्यूशन करना पड़ेगा तब जाके वो डाटा कहीं वापस आने वाला है तो आइर जीरो रेवोल्यूशन और वन रेवोल्यूशन तो इसका
कंक्लूजन क्या है वी कैन टेक एवरेज सो एवरेज इज हाफ रेवोल्यूशन है ना क्योंकि मैं आपसे बोल रहा हूं प्रॉब्लम क्या
एग्जैक्ट टाइम हमको नहीं पता तो कितना टाइम ऑन एन एवरेज हम मान के चलते हैं द टाइम टेकन बाय अ डिस्क टू कंप्लीट हाफ
रेवोल्यूशन इज नोन एज रोटेशनल लेटेंसी तो आई थिंक ये पॉइंट भी क्लियर इसमें कोई कंफ्यूजन अभी आपको नहीं होगा नेक्स्ट जो
इन्वेस्टिगेट करते हैं यहां पे दैट इज ट्रांसफर टाइम अभी आप सोचिए सीक टाइम भी हमारा खर्च हो गया रोटेशनल लेटेंसी भी
हमारा लग गया अभी जो रीड राइट ऑपरेशन करना वो कैसे करेंगे तो यहां पे इसको फार्मूला कैसे डिराइवर किया वो आपको समझाता हूं
जैसे ही हम डिजायर्ड पोजीशन पर पहुंचते हैं व्हाट वी अजम अजूम कि एक बार पोजीशन लेने के बाद इन वन कंप्लीट रेवोल्यूशन जो
हमारा हेडर है उसके पास कैपेसिटी है टू रीड और राइट वन कंप्लीट ट्रैक यानी कि जितना पोर्शन उसके नीचे से होके निकलेगा
एक रेवोल्यूशन में एक ट्रैक को कंप्लीट हम रीड या राइट कर सकते हैं है ना तो मान लीजिए फॉर एग्जांपल जो फाइल है उसका जो भी
साइज है अगर मैं फाइल साइज को डिवाइड कर देता हूं ट्रैक साइज से तो बोलो क्या होगा हमें पता लगेगा हमारी फाइल कितने ट्रैक
में यू नो फैली हुई है कितने ट्रैक के अंदर आई है मान लीजिए मैं बोल देता हूं फाइल जो है दैट इज ऑफ साइज 8 एब और ट्रैक
जो है दैट इज ऑफ साइज ऑफ़ 2mb तो 8mb / 2mb हम समझ गए कि अच्छा हमारी जो फाइल है ना वो चार ट्रैक के अंदर आई है मानते हो
इस बात को तो फोर ट्रैक्स है एक चक्कर में मैं एक ट्रैक पढ़ पाता हूं तो फोर ट्रैक पढ़ने में कितना लगेगा चार रोटेशन करना
पड़ेगा तो व्हाट वी कैन डू फाइल साइज बाय ट्रैक साइज बेसिकली क्या मिला हाउ मेनी अ व्हाट शुड आई से हाउ मेनी रोटेशंस हाउ
मेनी अ सेक्ट ट्रैक आर देयर कितने ट्रैक लगे एक ट्रैक को पढ़ने में एक तो नंबर ऑफ ट्रैक्स को मल्टीप्लाई कर दो टाइम ऑफ वन
रेवोल्यूशन तो आपको क्या मिल जाएगा टोटल टाइम मिल जाएगा तो तीन चीजें यहां पर फैक्टर बनी कौन-कौन सा सीक टाइम रोटेशनल
लेटेंसी ट्रांसफर टाइम आगे जब इस पे न्यूमेरिकल सॉल्व करेंगे तो ये बात और अच्छे से डिटेल में आपको समझ आएगी यस तो
दोस्तों अभी जो अगला प्रॉब्लम हमें हैंडल करना है वो है डिस्क शेड्यूलिंग ट्रांसफर टाइम का बेसिक अंडरस्टैंडिंग हमने देख
लिया उस पर आगे प्रॉपर न्यूमेरिकल सॉल्व करेंगे डिश शेड्यूलिंग का प्रॉब्लम क्या पहले आपको समझाता हूं एंड आई विल गो पॉइंट
बाय पॉइंट सो दैट कोई पॉइंट हम मिस ना करें और कहीं बहुत ज्यादा बात ना करें सी वन ऑफ द रिस्पांसिबिलिटी ऑफ ऑपरेटिंग
सिस्टम इज इज टू यूज द हार्डवेयर एफिशिएंटली एंड फॉर डिस ड्राइव्स एफिशिएंसी मींस लेस सीक टाइम लेस वेटिंग
टाइम एंड हाई डेटा ट्रांसफर रेट देखो अभी तक हम ज्यादातर थोड़ा सा सीपीयू सेंट्रिक रहे हैं अब जाके थोड़ा कंसंट्रेट कर रहे
हैं इनपुट आउटपुट डिवाइस पे बात तो एकदम ठीक है और जब हम बोलेंगे हमें अच्छा एल्गोरिथम बनाना है अच्छे से काम करना है
एफिशिएंसी चाहिए तो वेटिंग टाइम कम होना चाहिए सीक टाइम कम होना चाहिए तो डेटा ट्रांसफर रेट है वो ज्यादा होना चाहिए वी
कैन इंप्रूव ऑल दिस बाय मैनेजिंग द ऑर्डर इन विच द इनपुट आउटपुट रिक्वेस्ट आ सर्विस अब मैं इस बात का मतलब समझाता हूं कि
ऑर्डर चेंज करके आप मैनेज कर सकते हैं देखिए ये जो डेटा ट्रांसफर रेट है जरा सोच के मुझे बताइए ये जो कंपोनेंट है ना ये
तीन कंपोनेंट थे ना सीक टाइम रोटेशनल टेंस ट्रांसफर टाइम क्या हम ट्रांसफर टाइम चेंज कर सकते हैं सर ये सीपीयू बस टाइम की तरह
है फाइल को प्रोसेस को जितना रीड राइट ऑपरेशन करना है उतना ही करेगा डिस्क अपनी स्पीड से ही रोटेट करेगा आप कित ना भी
दिमाग लगा लो डाटा ट्रांसफर रेट चेंज नहीं हो सकता व्हाट अबाउट द रोटेशनल लेटेंसी ये तो पहली रैंडम फंक्शन है आप सोचो ना डिस्क
घूम रही है हमने ऑलरेडी समझाया इन द बेस्ट केस इट कैन बी जरो इन द वर्स्ट केस इट कैन बी टाइम टेकन जस्ट टू कंप्लीट वन रोटेशन
वैसे भी इतना ज्यादा नहीं होना हाफ टाइम हम लेते हैं सीक टाइम यार ये इंपॉर्टेंट है इसका गेम समझो क्या है हमारे पास डिस्क
में अलग-अलग ट्रैक्स है ये बात समझ आ रही है और ट्रैक्स के अलग-अलग नंबर है नाउ फॉर एग्जांपल मैं 0 1 2 3 ऐसा करके 99 तक नंबर
कर रहा हूं है ना तो इमेजिन कर लेना दिस इज अ लाइन इधर से जा रहा है ट्रैक नंबर रो देन वी हैव ट्रैक नंबर वन वी हैव ट्रैक
नंबर टू एंड सो ऑन एंड सो फॉर वी हैव ट्रैक नंबर 99 अब रिक्वेस्ट आती रहेगी अलग आप समझ रहे हो ना सिस्टम चल रहा है बहुत
सारी प्रोसेस है कंपलीट कर रही है इनपुट आउटपुट ऑपरेशन करना है कोई कह रहा ट्रैक नंबर 24 कोई कह रहा ट्रैक नंबर 48 कोई कह
रहा ट्रैक नंबर टू कोई कह रहा ट्रैक नंबर 92 ऐसा जब रिक्वेस्ट मेरे पास है अब मेरे पास एक प्रॉब्लम है क्या कि मैं पहले
किसको सेटिस्फाई करूं और अगर मैं इस ऑर्डर को चेंज करता हूं तो मेरा सीक टाइम चेंज होगा ध्यान से समझो इस बात को है ना तो अब
एक इंपॉर्टेंट एल्गोरिदम जो मैं पढ़ना डिश शेड्यूलिंग प्रॉब्लम क्या प्रॉब्लम यही है ये अब लास्ट ंड दोबारा पढ़ो वी कैन
इंप्रूव बाय मैनेजिंग द ऑर्डर इन व्हिच द इनपुट आउटपुट रिक्वेस्ट आर सर्विस जिस ऑर्डर में मैं इनपुट आउटपुट रिक्वेस्ट
सर्विस करूंगा उसी ऑर्डर में मेरा सीक टाइम चेंज होगा बहुत सारे पॉइंट ऑफ व्यू हो सकते है कोई कहे कि एक काम करो ना जो
आपके पास में रिक्वेस्ट है पहले उसे सेटिस्फाई कर लो सीक टाइम कम लगेगा बट ऐसा ना हो जो बहुत दूर है वो स्टार्वेशन में
चला जाए इस तरह के बहुत सारे पॉइंट ऑफ व्यू हो सकते हैं डिजाइन करने के लिए बट यस किस ऑर्डर में आप रिक्वेस्ट सर्विस
करेंगे ये एक इंपॉर्टेंट आईडिया होने वाला है आगे बढूं व्हेन सेवरल इनपुट आउटपुट नीड्स अ इनपुट आउटपुट टू और फ्रॉम द डिस्क
इट इज अ इशू दैट द सिस्टम कॉल ऑपरेटिंग सिस्टम द रिक्वेस्ट में स्पेसिफाई इंफॉर्मेशन ब्ला ब्ला ब्ला कंट्रोलर
अवेलेबल है इमीडिएट करेंगे अगर अवेलेबल नहीं है तो आप क्यू में चले जाएंगे अब जब एक रिक्वेस्ट कंप्लीट होगी ऑपरेटिंग
सिस्टम अब चूज करेगा कि यार अगला मैं इसको सेटिस्फाई करूं और यह जो आंसर है यह आंसर करेगा डिस्क शेड्यूलिंग एल्गोरिथम हर
एल्गोरिथम का क्या थॉट प्रोसेस है वो ऐसा क्यों कर रहा है एग्जांपल सब समझेंगे विश्वास मानिए आपको मजा आ जाएगा सो आई विल
गो वन बाय वन अगेन सबसे सिंपल हर जगह जब भी हमने रिसोर्स मैनेजमेंट किया है जो पहला सबसे सिंपल अप्रोच हमने हमेशा यूज़
किया दैट इज नथिंग बट फर्स्ट इन फर्स्ट आउट फर्स्ट कम फर्स्ट सर्व और फर्स्ट इन फर्स्ट आउट और एफसीएफएस अब मैं एक
एग्जांपल ले लेता हूं देन आई विल कम बैक टू द आईडिया थ्योरी उसके बाद आप समझ जाएंगे यहां पर देखिए एक क्यू हमारे पास
है सो आई एम टेकिंग एग्जांपल फ्रॉम गैल्विन हमारे पास एक क्यू है एंड व्हाट आर दीज दीज आर द ट्रैक नंबर्स तो कोई कह
रहा है कि मेरे को ना इसी ऑर्डर में रिक्वेस्ट आए हैं ट्रैक नंबर 98 ट्रैक नंबर 183 37 ब्ला ब्ला ब्ला एंड ट्रैक
नंबर 67 तक रिक्वेस्ट है एंड राइट नाउ मेरा जो हेड का पोजीशन है दैट इज अ ट्रैक नंबर 53 अब क्वेश्चन ये है कि किस ऑर्डर
में रिक्वेस्ट सेटिस्फाई होना चाहिए आंसर इज डिसऑर्डर में आया है है ना तो रिसोर्स मैनेजमेंट का जो सबसे फंडामेंटल प्रिंसिपल
वा वो क्या है जिस ऑर्डर में रिक्वेस्ट आया मैं उसी ऑर्डर में सेटिस्फाई करूंगा मेरे को इस बात से कोई लेना देना ही नहीं
है कि क्या मुझे हेडर की मूवमेंट ज्यादा लेने पड़ेंगे कम लेने पड़ेंगे कैसा एफर्ट चलेगा सो इट इज ओके ट्राई करके देख लीजिए
और आप अप्रोच बताइए समझ आता है क्या सो देयर यू सी 53 से स्टार्ट किया अगला नंबर 98 सो देयर यू सी हम गए 98 के ऊपर देन 183
तो बस ये थोड़ा सा इट इज लाइक दिस की नीचे की तरफ आपको दिखा रहा है टाइम तो जैसे-जैसे टाइम आगे बढ़ रहा है दिखा रहा
है हेडर कैसे मूव हो रहा है इसमें आगे कुछ करने के लिए है नहीं 183 एंड देन 37 एंड देन 122 एंड देन 14 तो काइंड ऑफ जिगजैग
मूव भी होंगे ज्यादा मूव करने पड़ेंगे बट हम ऑर्डर मेंटेन कर रहे हैं है ना देन 124 एंड देन 65 एंड देन 67 सो ये कहानी हो गई
किसकी फर्स्ट कम फर्स्ट सर्व की अगर मैं एक बार अब इफ आई गो बैक टू द आइडिया द सिंपलेस्ट डिश शेड्यूलिंग बात तो ठीक है
फर्स्ट कम फर्स्ट सर इन इफ द रिक्वेस्ट आर एड्रेस इन द ऑर्डर इन व्हिच दे अराइव इन द डिस्क क्यू एल्गोरिथमिक इज इंटेंस ली फेयर
बट जनरली डू नॉट प्रोवाइड द फास्ट सर्विस टाइम फेयर तो है कोई परेशान नहीं हो सकता कोई यह नहीं कह सकता कि मैं स्टार्वेशन
में हूं सिंपल है इजी टू इजी टू अंडरस्टैंड है इजी टू इंप्लीमेंट है और हम जैसा बोलते हैं कन्वो इफेक्ट हो सकता है
हो सकता है आपसे जो पहले आए एक और बात यहां पर ना इस बात को नोटिस करना हम बहुत ज्यादा कंसंट्रेट सी टाइम पे कर रहे बट
ऐसा नहीं यहां जाके जीरो टाइम लगता है अब यहां जाके जो भी इनपुट आउटपुट ऑपरेशन होना होगा होगा बट द पॉइंट इज उसके बारे में
वैसे भी कुछ नहीं कर सकता तो उस पॉइंट प हम कंसंट्रेट नहीं कर रहे हम सिर्फ देख रहे हैं कि सीक मूवमेंट कितना लगा है ना
दैट इज इट डिसएडवांटेज क्या है ना तो इसमें वेटिंग टाइम को हमने ऑप्टिमाइज किया हमें नहीं पता किस प्रोसेस को कितना वेट
करना पड़ा होगा ना ही हमने ये जो मूवमेंट लेने पड़ रहे हैं हेडर को सीक मूवमेंट ना ही हमने उसे ऑप्टिमाइज किया बात तो ठीक है
दोनों में से एक भी आईडिया को ऑप्टिमाइज नहीं किया तो अगर इसमें थोड़ा दिमाग लगाएं तो क्या इससे अच्छे एल्गोरिथम बनाए जा
सकते हैं शायद हां एंड देन बीइंग प्योर ग्रीडी जो एक अप्रोच हमेशा आपके दिमाग में आनी चाहिए वहां पे पेज रिप्लेसमेंट में भी
हमने बात की ऑप्टिमल की सीपीय शेड्यूलिंग में हमने बात की शॉर्टेज ऑफ फस की यहां पर बात कर रहा हूं एसएसटीएफ स्टैंड्स फॉर
शॉर्टेस्ट सीक टाइम फर्स्ट ना व्हाट डज दैट मीन अगेन सिंपलेस्ट अप्रोच है इफ आई एम बीइंग प्योर ग्रीडी मैं जो भी हेडर
रिक्वेस्ट करूंगा हेडर का रिक्वेस्ट सेटिस्फाई करूंगा जिस भी ट्रैक नंबर पे मैं हूं मैं अगला नंबर किसको लूंगा इस बार
मैं इस बात को रिस्पेक्ट नहीं कर रहा कि कौन किस ऑर्डर में आया था मैं देखूंगा या मेरे क्लोजेस्ट कौन है बिकॉज़ जो मेरे
क्लोजेस्ट होगा वहां तक जाऊंगा तो मुझे मिनिमम सीक टाइम लगे मिनिमम सीक एफर्ट मेरे को करना पड़ेगा सो थिंग दिस आइडिया
देयर यू सी पूरा गेम सेम है आई एम एट ट्रैक नंबर 53 एंड दीज आर ऑल द रिक्वेस्ट अराइव इन द सेम ऑर्डर नाउ दिस टाइम यू कैन
सी कैसे कहानी चेंज हो रही है कैसे सो 53 के क्लोजर्स कौन रहा होगा नीचे जाऊंगा आई थिंक 37 ज्यादा दूर है 65 पास में तो 53
टू 65 एंड देन 67 यहीं पे कंप्लीट कर लिया अभी 67 से आइर आई कैन गो टू 98 आई थिंक और आई कैन गो टू 37 सो ये थोड़ पास है सो य
गो बैक टू 37 एंड देन 37 से 14 एंड देन फाइनली 98 एंड देन 22 एंड देन 124 एंड फाइनली 183 लाइक दिस इन जनरल ओबवियसली
एक्सपेक्टेड है अगर आप शॉर्टेस्ट सीक टाइम यूज करेंगे आमतौर पे नंबर ऑफ सीक मूवमेंट्स आपको कम लगेंगे हालांकि मैं एक
बात आपको बता दूं यह ऑप्टिमेलिटी की गारंटी नहीं लेता है क्यों बिकॉज़ यू कैन प्ले विद इट कभी-कभी ना आप यू नो x एंड
देन x + 1 इस तरह से इसको इतना जिगजैग मूव करा सकते हो कि कंफ्यूज हो जाएगा मैं एक एग्जांपल कोट करता हूं मान लीजिए सपोज यू
आर ए ट्रैक नंबर 50 पहला रिक्वेस्ट आपने 51 पे किया अब यह 51 पे किया ना तो मैं इसको वापस लेके जाता हूं सपोज अगला नंबर
मैं रखता हूं 48 तो ओबवियसली 48 से 51 में इधर जाएगा अब 48 और 51 में कितना डिस्टेंस हुआ 3 का 3 + 1 4 तो ये मैं डिस्टेंस कर
देता हूं 55 समथिंग लाइक दिस तो ऐसा मैं इसको जिगजैग मूव करा सकता हूं तो दे कैन बी सम एक्सट्रीम केसेस जहां पे अ यू नो जो
सीक ये जो हमारा है शॉर्टेज सीक टाइम फर्स्ट ये मिनिमम नंबर ऑफ सीक मूवमेंट्स की गारंटी ना ले बट इन जनरल ये मिनिमम काम
करता है नाउ वी गेट बैक द आईडिया आईडिया क्या है मेजर कंपोनेंट ऑफ द टोटल ट्रांसफर टाइम इज द सीक टाइम इस बात पे मैं ऑलरेडी
आपसे बात कर चुका हूं इन ऑर्डर टू रिड्यूस द सीक टाइम इफ द सर्विस ऑफ ऑल द रिक्वेस्ट अ रिक्वेस्ट क्लोज टू द करंट हेड पोजीशन
फिर वही बात बोल रहा है कि जो मेरा हेड का पोजीशन है अगर उसके सबसे पास वाले को मैं यू नो उस ऑर्डर में मैं रिक्वेस्ट
सेटिस्फाई करूं तो इन जनरल मेरे को मिनिमम मेरे को कम एफर्ट मिलेगा कम सीक करना पड़ेगा लेकिन मैं दोबारा आपको बोल रहा हूं
बेटर ये काम करता है एफसीएफएस से इस रिगार्ड में बट ये ऑप्टिमल नहीं है है ना एडवांटेज सीक मूवमेंट डिक्रीज करेंगे अगर
सीक टाइम कम लगेगा तो ओवरऑल थ्रू पुट भी इंक्रीज होगा प्रॉब्लम क्या है एक तो आपको बार-बार ये कैलकुलेट करना पड़ेगा को सपना
थोड़ी आ रहा है पहले कैलकुलेट करना पड़ेगा कि फिलहाल हमारा हेड का जो पोजीशन है वहां पे सबसे क्लोजेस्ट सीक टाइम क्या होगा
पॉइंट नंबर वन पॉइंट नंबर टू स्टार्वेशन तो होना ही था जब भी आप किसी एटिबल के रिगार्ड किसी चीज को सपोर्ट करेंगे कोई
दूसरा नुकसान में जाएगा ही जाएगा उसमें कोई डाउट नहीं है तो यहां पे ऑब्स एक प्रॉब्लम होने वाली है अगर आप आसपास के
रिक्वेस्ट सेटिस्फाई करोगे और इमेजिन करिए कि मशीन ऐसा है जहां बहुत सारी प्रोसेस लगातार रिक्वेस्ट जनरेट कर रही है तो होगा
क्या हेडर डिस्क के किसी एक स्पेसिफिक सेक्शन में बस यू नो अटक के रह जाएगा वहीं आसपास घूमता रहेगा और वो रिक्वेस्ट जो
करंट हेड की पोजीशन से दूर है का कभी नंबर नहीं आएगा तो स्टार्वेशन का एक प्रॉब्लम हो सकता है इस प्रॉब्लम को कैसे रिजॉल्व
करें सोचिए अगर लोड ज्यादा होगा तोस इज गोइंग टू बी अ कंप्लीट फेलियर तो क्या काम करें एक बहुत शानदार एल्गोरिथम है इसका हो
सकता है आपने नाम सुना हो यूनिवर्सिटी एग्जाम सेमेस्टर्स में तो बड़ा इंपॉर्टेंट है कॉम्पिटेटिव एग्जाम में कई बार मैंने
क्वेश्चन देखे इस पे इज लाइक स्कैन और एलिवेटर एल्गोरिथम क्या बोलते हैं स्कैन और एलिवेटर ना व्हाट डज दैट मीन इसका नाम
स्कैन या एलिवेटर एलिवेटर समझते हो एलिवेटर और लिफ्ट बोलते हैं ना बिल्डिंग के अंदर सो इट्स लाइक कि लिफ्ट जब काम
करती है ना लोड थोड़ा सा ज्यादा होता है तो आमतौर पे ऐसा नहीं होता कि इधर जा रही है या आप जो जिस फ्लोर प बोलोगे एगजैक्टली
उसी प जाएगी वन टाइम्स द लिफ्ट इज गोइंग अप एंड अनदर टाइम द लिफ्ट इज गोइंग डाउन इमेजिन करिए कोई ऐसी बिल्डिंग है जिसमें
30 40 50 फ्लोर्स है तो बार-बार मैं चेंज नहीं करूंगा मैं फर्स्ट कम फर्स्ट सब नहीं कर सकता मैं शॉर्टेस्ट नहीं कर सकता कि 18
का दोबारा मैं 16 पे चला गया फिर 20 पे जाऊंगा ना एक बार लिफ्ट ऊपर जाएगी एक बार लिफ्ट नीचे आएगी कभी-कभी आपने सुना भी
होगा आप जैसे यू नो यू प्रेस द बटन ओपन होती है तो लोग पूछते हैं ऊपर जा रही है कि नीचे जा रही है ऊपर जा रही है चलो फिर
कोई मतलब नहीं है दे स्टे आउट ऑफ इट जब नीचे जाएगी तो बैठेंगे बिकॉज वे फालतू में ऊपर जाना एंड देन नीचे आना सेम अप्रोच पे
यहां स्कैन काम करता है तो मैं अप्रोच आपको समझाता हूं उसका इधर तो आ ही जाएंगे आईडिया ये है सर जो भी मेरा डिस्क पे
पोजीशन है है ना मैं ना तो यह देखने वाला कि रिक्वेस्ट कहां आई किस ऑर्डर में आई किस ट्रैक तक आई मेरे को मतलब नहीं मैं
जहां से भी शुरू किया मैं जाऊंगा लास्ट ट्रैक नंबर तक कहां तक जा रहा हूं मैं लास्ट ट्रैक नंबर तक लास्ट रिक्वेस्ट तक
नहीं जा रहा मैं देख ही नहीं रहा ना रिक्वेस्ट को मैं लास्ट नंबर तक जाऊंगा फिर वापस आऊंगा फिर जाऊंगा फिर वापस आऊंगा
इन अ जिगजैग मूव इन अ जिगजैग मूव और ऐसा मैं करते जाऊंगा ऐसा करने से इन जनरल सोचिए क्या-क्या एडवांटेज मिलेगा बहुत
ज्यादा रैंडम मूव्स भी नहीं करने पड़ेंगे तो सीक टाइम भी रिलेटिवली अच्छा होगा इतना खराब नहीं होगा दूसरा स्टार्वेशन का
प्रॉब्लम वो चला जाएगा कोई यह नहीं कह सकता सर हम हमा पोजीशन हेड से बहुत दूर थी तो हमारा नंबर ही नहीं आ रहा ना मैं तो
जिगजैग मूव करते जा रहा हूं जो जो रिक्वेस्ट आती जाएगी वो रिक्वेस्ट सेटिस्फाई होती जाएगी ये अप्रोच कहलाता है
स्कैन यू कैन आल्सो इमेजिन एग्जांपल ऑफ अ ट्रेन सोचो ना ट्रेन क्या किसी स्टेशन पर रुक जाती है अगर उसके आगे जाने वाले लोग
ना हो अब आमतौर पर ट्रेन पर लोड इतना ज्यादा होता है कि मुंबई से अगर दिल्ली जा रही है ट्रेन और जयपुर खाली हो गई तो ऐसा
नहीं ड्राइवर वहीं से ट्रेन कैंसिल हो जाती है इट विल गो टिल यू नो दिल्ली ओनली जाएगी अपना पूरा जर्नी कंप्लीट करेगी सेम
अप्रोच इधर है स्कैन तो यहां पर अब आप देखो 53 पे हम थे मान रहे थे कि फिलहाल हेड नीचे की तरफ जा रहा था अब ऑब् वियस
यहां पे रुक गया क्योंकि रिक्वेस्ट खत्म हो गई वरना मेरा अप्रोच क्या है मैं यहां तक गया मेरा लास्ट नंबर 14 था बट स्टिल आई
एम गोइंग टू गो एंड टच द ज़ीरो एंड देन आई विल डू दैट और मैं वहीं पे रुक जाऊंगा जहां पे मेरी फाइनल सारी रिक्वेस्ट
सेटिस्फाई हो रही है तो ये अप्रोच ये आईडिया आमतौर पर बढ़िया काम करेगा उन सिस्टम्स में जिन पे लोड ज्यादा है दैट इज
व्हाई यू कॉल्ड इट स्कैन सिंपल इजी टू अंडरस्टैंड बात ठीक ठीक है स्टार्वेशन का भी कोई प्रॉब्लम नहीं है लो वेरियंस एंड
एवरेज रिस्पांस टाइम इज गुड व्हाई लो वेरियंस फिर वही स्टार्वेशन नहीं है तो हर कोई अंदाजा लगा सकता है इतने टाइम में तो
मेरा नंबर आ आ ही जाएगा क्योंकि वो जा रहा है और वापस आ रहा है मेरा नंबर आ जाएगा प्रॉब्लम इसके अंदर क्या है ध्यान से आप
सोचेंगे ना अब मान लीजिए मैं इसमें एक और अच्छा एग्जांपल सोचता हूं इमेजिन करिए मैं सफाई कर रहा हूं इट्स लाइक अ बिग कॉरिडोर
और रेलवे स्टेशन एक तरह से सफाई करते करते करते करते नेक्स्ट पॉइंट पे क्या अभी जैसे ही मैं आप पहुंचा ना इमेजन करो तो इधर तो
मैंने लास्ट वाले पॉइंट पर तो जस्ट तुरंत अभी क्लीनिंग कि है तो आपको नहीं लग रहा कि लास्ट वाला पोर्शन ज्यादा साफ होगा अब
हुआ क्या मैं साफ करते-करते इधर आया मैं इधर से साफ करते करते फिर वापस आ रहा हूं इमेजिन करिए हेड यहां से निकला था और
निकलते ही यहां पे कोई रिक्वेस्ट आई पर अभी प्रॉब्लम ये है ये रिक्वेस्ट पेंडिंग रहेगी मैं जाऊंगा जाऊंगा जाऊंगा और फिर
मैं वापस आऊंगा तो ये काइंड ऑफ ये वाला जो रिक्वेस्ट है इसके लिए थोड़ा सा प्रॉब्लम है नेटवर्क की बात करें तो टू टीपी पहले
प्रोपेगेशन जाना फिर प्रोपेगेशन आना ये थोड़ा सा प्रॉब्लम है तो इसके अंदर कुछ इंप्रूवमेंट हो सकता है एक और बात अगेन
अगर लोड बहुत ज्यादा नहीं है देन अगेन इट आल्सो डजन मेक सेंस कि यार आप ना एकदम लास्ट तक जा रहे हो रुक जाओ ना बीच में तो
इंस्टेड ऑफ गोइंग टिल लास्ट ट्रैक नंबर देयर कुड बी एन आइडिया कि यू गो टिल लास्ट रिक्वेस्ट एकदम ट्रैक नंबर तक मत जाओ
लास्ट रिक्वेस्ट तक जाओ वहीं से मुड़ जाओ तो देयर आर मल्टीपल ऑप्शंस की मैं इसमें इंप्रूवमेंट कर सकूं और स्कैन का जो पहला
इंप्रूवमेंट है दैट इज कॉल्ड सी स्कैन मैं अगेन आपको अप्रोच समझाता हूं उससे आप समझ जाएंगे लॉजिक वही है अब हम क्या करेंगे हम
रिक्वेस्ट सिर्फ एक डायरेक्शन में सेटिस्फाई करेंगे और वापस सीधे आएंगे फिर एक डायरेक्शन में रिक्वेस्ट सेटिस्फाई
करेंगे वापस सीधे आएंगे क्यों क्योंकि जैसे ही हम रिक्वेस्ट सेटिस्फाई करते-करते लास्ट तक गए हमको पता है कि लास्ट वाले
पार्ट में वैसे भी ज्यादा रिक्वेस्ट नहीं होंगी क्यों अभी तो हम सेटिस्फाई करते आए हैं तो वापस जाते हुए कोई रिक्वेस्ट
सेटिस्फाई नहीं करो सीधे वापस और फिर इस ऑर्डर में सेटिस्फाई करो लाइक अगेन सफाई वाला एग्जांपल आप इधर से झाड़ू पोचा लगाते
लगाते लास्ट स गए तो ये तो अभी साफ हुआ है यू गो बैक एंड अगेन यू यू नो यू क्लीन इन द सेम ऑर्डर आप बोलेंगे सर वापस आने में
सीक टाइम लगेगा लगेगा बट उसका इतना वैल्यू नहीं क्यों क्योंकि वापस आते हुए ना मैं किसी का रिक्वेस्ट सेटिस्फाई नहीं कर रहा
मैं जस्ट हेडर को एक बार मूव करूंगा तो सीफ की टर्म्स में आपको लगेगा थोड़ा पेनल्टी है बट ये एक्चुअली इतना सीवियर
पेनल्टी नहीं है बिकॉज़ यू डायरेक्टली इज कमिंग देयर एंड देन यू आर डूइंग दिस वर्क तो जैसे आप एग्जांपल देखिए अब यहां पे 53
से आई एम गोइंग अप बट देयर यू सी अगेन मैं स्टिल लास्ट ट्रैक तक जा रहा हूं ये लास्ट रिक्वेस्ट तक मैं अभी भी लास्ट ट्रैक तक
जा रहा हूं तो मैं लास्ट ट्रैक तक गया ऊपर जाते हुए जो रास्ते में रिक्वेस्ट आई मैंने सेटिस्फाई की बट देर यू सी देर यू
सी द ब्यूटी वापस आते हुए मैं किसी का कोई रिक्वेस्ट सेटिस्फाई नहीं कर रहा आई एम डायरेक्टली गोइंग टू ट्रैक नंबर जीरो फिर
से ऊपर जाते हुए रिक्वेस्ट सेटिस्फाई करूंगा तो यह एक आईडिया है यह एक अप्रोच है जो यहां पर काम करता है इसीलिए इसका
नानाम क्या है इसका नाम है सर्कुलर स्कैन तो वही पूरा पॉइंट लिखा है व्हेन द डिस्क रीच वन एंड ऑफ द डायरेक्शन फ्यूअर
रिक्वेस्ट आर नियर बाय सिंस दीज सिलेंडर्स और यू नो ट्रैक्स हैव जस्ट बीन सर्विस उसको अभी सर्विस किया है तो अगेन मैंने
लॉजिक आपको बता दिया रिटर्न ट्रिप पे यू इमीडिएट रिटर्न और कोई सर्विस मत करो एडवांटेज यहां पे वेटिंग टाइम और बेटर हो
जाएगा और यूनिफॉर्म होगा क्योंकि लगभग लगभग सबको मैं सेम ऑर्डर में सर्विस कर रहा हूंगा रिस्पांस टाइम भी बेटर होगा
प्रॉब्लम अब अगेन थोड़ा सा सीक टाइम आपका बढ़ेगा क्योंकि आप वापस आते हुए काइंड ऑफ कुछ काम नहीं कर रहे बस पूरा डिस्क स्कैन
करते हुए आपको वापस आना है तो ये एक छोटा सा इशू यहां पर है इसी का एक और इंप्रोवाइज वर्जन है दैट इज कॉल्ड लुक नाउ
व्हाट इज दिस इट्स का मतलब है कि अगेन देखो तो देखो वाला मतलब क्या है अगेन ये सी स्कैन का इंप्रूवमेंट नहीं ये स्कैन का
ही इंप्रूवमेंट है ये क्या बोल रहा है ये बोल रहा है मैं रिक्वेस्ट दोनों डायरेक्शन में ही सेटिस्फाई करूंगा नो प्रॉब्लम इन
दिस बट बट बट मैं लास्ट ट्रैक तक नहीं जाऊंगा मैं लास्ट रिक्वेस्ट तक जाऊंगा इस बात को कोई मतलब नहीं अगर उस पॉइंट से आगे
रिक्वेस्ट है ही नहीं तो वहां तक जाके टच करके आने का क्या ही मतलब बनता है बात ठीक भी है बहुत अजीब नहीं है तो यू गो टिल
लास्ट रिक्वेस्ट एंड देन यू कम बैक अगर मैं लास्ट वाले वेरिएंट में आपको चेंज करके दिखाऊं ये बिल्कुल सेम है मैं ऐसे
ऐसे ऐसे आगे जाता और मेरा लास्ट रिक्वेस्ट अगर 183 पे है तो मैं यहीं से वापस आ गया होता मैं 199 पे नहीं जाता और अगर बात
सिर्फ लुक की है तो मैं दोनों डायरेक्शन में रिक्वेस्ट सेटिस्फाई करता तब वापस आते-आते आई थिंक एक रिक्वेस्ट में 37 पे
करता एक 14 पे करता और यहीं पे एंड हो जाता तो दोनों इंप्रूवमेंट नहीं ले रहा इसका ऐसा समझिए अ ये ना दो वेरिएंट्स है
मैं इसको समझाता हूं आपको ऐसे स्कैन हो गया हमारा बेसिक आईडिया स्कैन में दो सेपरेट इंप्रूवमेंट्स हमने किए एक सेपरेट
इंप्रूवमेंट था सी स्कैन व्हिच इज लाइक सर्कुलर स्कैन जिसने बोला जाएंगे लास्ट तक लेकिन रिक्वेस्ट एक ही डायरेक्शन में
सेटिस्फाई करेंगे दूसरा अप्रोच हुआ लुक दूसरा अप्रोच हुआ लुक लुक ने क्या बोला लास्ट तक नहीं जाएंगे लास्ट रिक्वेस्ट तक
जाएंगे है ना लेकिन दोनों डायरेक्शन में रिक्वेस्ट सेटिस्फाई करेंगे बोल रहा था एक ही डायरेक्शन में करेंगे अब अगर मैं अब
अगर मैं दोनों का एडवांटेज मिला दूं एंड लेट मी हैव अ न्यू आइडिया कॉल्ड सीलो अब बोलो ये क्या
करेगा सोचो तो यह ना तो लास्ट ट्रैक तक जाएगा यह लास्ट रिक्वेस्ट तक जाएगा क्योंकि यह लुक है लुक माने देखो यह देख
के काम करेगा पॉइंट नंबर टू ये क्योंकि सर्कुलर वेरिएंट है ये दोनों डायरेक्शन में भी रिक्वेस्टेड टफाई नहीं करेगा एक ही
डायरेक्शन में करेगा एंड देन अगेन विल कम बैक तो कैन यू गेस किस तरह का अप्रोच मिलेगा देखो दोनों का मिक्सचर समझ आ रहा
है क्या सो हियर यू सी दिस आइडिया कि मैं सिर्फ ऊपर जाते हुए रिक्वेस्ट सेटिस्फाई कर रहा हूं यस तो मैंने किया किया किया और
यहां देखिए 183 से रिटर्न हो गया इसका मतलब मैं लास्ट ट्रैक तक जा रहा हूं कि लास्ट रिक्वेस्ट तक मैं लास्ट रिक्वेस्ट
तक जा रहा हूं सो इट इज लुक वापस आते हुए क्या मैंने किसी का सेटिस्फाई किया कि रिक्वेस्ट नहीं किया बट स्टिल मैं लास्ट
ट्रैक तक गया के रिक्वेस्ट तक मैं लास्ट रिक्वेस्ट तक गया और वापस आते हुए रिक्वेस्ट सेटिस्फाई नहीं किया इसका मतलब
ये सर्कुलर वर्जन है एंड देन अगेन आई गो बैक और मैं वहीं पे रुक जाऊंगा जहां पे रिक्वेस्ट सेटिस्फाई हो रही है सो आई थिंक
डिस्क शेड्यूलिंग का एक जो ओवरऑल मैकेनिज्म है य चार पाच छह जो एल्गोरिथम है ये आपको अच्छे से समझ आए होंगे बेसिक
आईडिया है यस नाउ कमिंग बैक टू ये वाला अप्रोच इसमें अगेन याद हो आपको तो तीन टाइम हमने पढ़े अब इसमें थोड़ा ट्रांसफर
टाइम वाले एक दो न्यूमेरिकल सॉल्व करते हैं यहां से क्वेश्चन एक्सपेक्टेड है और एक दो न्यूमेरिकल आप सॉ करेंगे तो
अंडरस्टैंडिंग अच्छी होगी हमें पता है कि टोटल ट्रांसफर टाइम में सीक टाइम रोटेशनल लेटेंसी और ट्रांसफर टाइम तीन कंपोनेंट है
एक छोटा सा क्वेश्चन देखो यह तो सिर्फ कैपेसिटी के ऊपर है लेकिन जैसे ऑपरेटिंग सिस्टम में हमने मेन मेमोरी मैनेजमेंट में
बेसिक बात सीखी यहां भी आपको समझ आएगा क्या बोल रहा है कंसीडर अ डिस्क वेयर देयर आर 512 ट्रैक्स अगर मैं एक छोटा सा आईडिया
आपको समझाऊं तो इस तरह से बहुत सारे ट्रैक्स होंगे एंड ओवरऑल हाउ मेनी ट्रैक्स आर देयर सर 512 ट्रैक्स है ईच ट्रैक्स इज
होल्डिंग अ इज कैपेबल ऑफ होल्डिंग 128 सेक्टर अब ऐसा समझ रहे हो ऐसा ऐसा ऐसा ऐसा ऐसा ऐसा टोटल काउंट करूंगा तो 128 डिवीजन
सेक्टर यहां पर है इन ईच सेक्टर इज हैविंग 256 बाइट फाइंड द कैपेसिटी ऑफ द ट्रैक एंड द डिस्क एंड द नंबर ऑफ वाइट रिक्वायर्ड टू
रीच द करेक्ट ट्रैक सेक्टर डिस्क ब्ला ब्ला ब्ला आई विल गो वन बाय वन तो एक-एक करके देख लेते हैं पहले बताओ टोटल कितना
ट्रैक है सर टोटल ट्रैक है 512 हर ट्रैक के अंदर कितना से सेटर है सर हर ट्रैक के अंदर 128 सेक्टर है एंड ईच
सेक्टर इज हैविंग हाउ मेनी बाइट्स ईच सेक्टर इज हैविंग 256 बाइट हम तो कंप्यूटर साइंस के लोग हैं हमें टू की पावर जल्दी
समझ आती है तो मेरे को बताओ व्हाट इज 512 सर इट इज 2 रे टू पावर 9 व्हाट इज 128 सर इट इज 2 रे टू पावर 7 व्हाट इज 256 इट इज
2 रे टू पावर 8 कितना हो गया ये 9 प् 7 करेंगे आई थिंक दिस विल बी 16 एंड 16 + 8 दिस विल बी 24 सो ट टू पा 24 बाइट्स आई एम
सॉरी और इट इज़ बेटर टू राइट 2 रे टू पावर 4 कितना हो गया 16 ना एंड 2 रे टू पावर 20 इज मेगा सो दैट इज गोइंग टू बिकम 16
मेगावाट ये आपका कैपेसिटी हो गया पूरे डिस्क का तो इस तरह से ऑब्जर्व कर सकते हैं रही बात नंबर ऑफ बिट्स की तो अगेन आप
वन बाय वन कर सकते हैं पहली नाइन बिट्स खर्चा हो जाएगा क्या करने में सही ट्रैक ढूंढने में क्योंकि 500 12 है ना 9 बिट
लगेगा ढूंढने में 2 रे टू पावर 9 इज 512 कॉमिनेशन इस पे भी हम बात कर चुके हैं फर्द सेवन बिट्स और लगेंगे यह पता लगाने
के लिए कि उस ट्रैक के अंदर कौन से सेक्टर पर जाना है एंड फर्द ट बिट्स और लगेंगे पता लगाने के लिए कि उस सेक्टर तक कौन सी
बाइट में जाना है तो बेसिक अंडरस्टैंडिंग है लेकिन जो डिस्क का पूरा ओरिएंटेशन है वो आई थिंक यहां पे आपको क्लियर हुआ होगा
एक क्वेश्चन सॉल्व करते हैं न्यूमेरिकल टाइप देखिए जरा क्या लिखा हुआ है आई विल गो वन बाय वन कंसीडर अ डिस्क वेर ए सेक्टर
कंटेन 512 बाइट्स देयर आर 400 सेक्टर्स पर ट्रैक 1000 ऑन द डिस्क ब्ला ब्ला ब्ला इफ अ डिस्क इज रोटेटिंग एट 1500 आरपीएम फाइंड
द टोटल टाइम रिक्वायर्ड टू ट्रांसफर अ फाइल ऑफ़ 1 एबी सपोज द सीक टाइम इज 4 मिली सेकंड आई विल गो वन बाय वन टोटल ट्रांसफर
टाइम कंटेन थ्री थिंग्स कौन-कौन सा बोलो सबसे पहला सीक टाइम देन रोटेशनल लेटेंसी एंड ट्रांसफर टाइम हम जानते हैं सीक टाइम
मैंने बोला था या तो इग्नोर करें बोलेगा या तो इग्नोर करो या तो गिवन करेगा तो इसने गिवन कर दिया थैंक यू सो मच सो नाउ
वी नो दैट सीक टाइम इज 4 मिली सेकंड रोटेशनल लेटेंसी कैसे निकाल थोड़ी कैलकुलेशन करते
हैं स्पीड बोला है डिस्क का 1500 1500 है 1000 है 1500 रिवोल्यूशन पर मिनट अभी 1 मिनट में अगर 1500 बार घूम रही तो 1 सेकंड
में कितना घूमेगा ऑब् वियस कम ही घूमेगा ना अलाव मी टू डिवाइड बा 60 1 मिनट में अगर 1500 चक्कर है तो 1 सेकंड में कितना
होगा सो 1500 / 60 इतना अभी इसको ऐसे ही छोड़ देता हूं सो इतना रोटेशन घूमेगा बट हमें उल्टा देखना है इतना रोटेशन अगर लगा
रहा है 1 सेकंड में तो एक रोटेशन लगाएगा कितने में सो दैट इज 6 डिवा बाय 150 और मेरे को मिली सेकंड में चाहिए सब मिली
सेकंड में तो अलाउ मी टू मल्टीप्लाई दिस बाय 1000 अभी बोलो कैसे चलेगा थ्री से जा रहा है यस स दैट इज फाइव अ यस एंड 52 0 सो
ये आ गया 4040 मिली सेकंड प्लीज अंडरस्टैंड 40 मिली सेकंड इज द टाइम ऑफ वन रिवोल्यूशन रोटेशनल टेंसी में हम क्या
लेते हैं वन रिवोल्यूशन हाफ हाफ रिवोल्यूशन तो क्या लूं सो अला मी टू टेक 20 मिली सेकंड तो यह वही टाइम है ना ट्रैक
प पहुंचने के बाद जो रियल सेक्टर है वो आप तक आए कितना समय लगेगा 20 मिली सेकंड लगे फाइनली द ट्रांसफर टाइम वो कैसे निकालते
हैं बहुत आसान है तो अगेन मुझे बताइए फाइल का कैपेसिटी क्या है हमने क्या समझा था पहले देखो फाइल कितने ट्रैक में आया है तो
फाइल साइज डिवाइडेड बाय ट्रैक साइज फाइल साइज इज 1 एब फेयर इनफ एंड व्हाट इज ट्रैक साइज तो उसने बोला है ईच सेक्टर कंटेन 512
बाइट्स पॉइंट नंबर वन 512 बाइट्स एंड देयर आर 400 सेक्टर्स 400 सेक्टर्स है ना मल्टीप्ला बाय 400 तो ये क्या आया सर एंड
दिस इज इन बाइट्स ओनली ना बाइट्स तो ये दोनों बाइट बाइट आया और ये किसका कैपेसिटी आ गया यह हमारे पास यहां पे कैपेसिटी आ
गया किसका कैपेसिटी ऑफ अ अ फाइल फाइल टोटल कितने ट्रैक ऑक्यूपाइड में मल्टीप्लाई कर लेंगे द टाइम ऑफ वन
रेवोल्यूशन एंड टाइप ऑफ वन रेवोल्यूशन इज 40 मिली सेकंड तो यह कैलकुलेशन मजेदार होगी बट
चलिए कैलकुलेटर कहां हो यस तो आई हैव कैलकुलेटर अब यह लिखा है इसको क्या करूं थोड़ा सा रफ कैलकुलेशन
होगा बट बाइट से बाइट कैंसिल हुआ अच्छा टू की बार में कर लेते ना व्हाट इज 1 ए दिस इज 2 रेट पावर 20 एंड दिस इज रे टू पावर 9
तो कितना बचेगा 2 रेट पावर 11 इज इट सो 2 रे टू पावर 11 इज 2048 इतना तो हम डायरेक्ट कर सकते हैं 2048 मल्ला बा 40 भी
कर लेता हूं एंड डिवाइडेड बाय 400 यस सो व्हेन आई डू सो व्हेन आई डू सो मेरे को मिल रहा है
24.8 24.8 अ सो अलाव मी टू राइट इट डाउन 24.8 और इस टोटल को सम करोगे तो दिस इज
गोइंग टू बिकम अ टू इधर आ जाएगा सो दिस इज 2 28.8 ये कैलकुलेशन देखना हो सकता है कैलकुलेशन
थोड़ा गड़बड़ हुआ हो बिकॉज रन टाइम पर कर रहा हूं जल्दी से बट बेसिक अंडरस्टैंडिंग आई थिंक आपको क्लियर है ट्रांसफर टाइम
कैसे निकालते हैं फाइल का साइज 1 एब डिवाइड बाय ट्रैक का साइज और डिवाइड किया और ये आया नंबर ऑफ ट्रैक्स कितने
ऑक्यूपाइड बाय हमने देख लिया कि रेवोल्यूशन में हमें कितना एफर्ट लग रहा है तो वो हमने यहां पर
मल्टीप्लाई किया यस यस सो आई होप दिस इज द करेक्ट आ आईडिया खैर सो डिस्क का जो पूरा अंडरस्टैंडिंग है वेदर डिस्क शेड्यूलिंग
और जो डिस्क ये जो ट्रांसफर टाइम है आई थिंक इस पर आपको क्लेरिटी आई होगी कोई न्यूमेरिकल आएगा आप सॉल्व करके आ सकते हैं
तो चलिए अब बात करते हैं कि सेकेंडरी मेमोरी में फाइल एलोकेशन कैसे करते हैं तो बहुत मजेदार कांसेप्ट है बहुत छोटा सा
कांसेप्ट है और कई बार मैंने यहां से क्वेश्चन देखा है ध्यान से देखिए सो तीन बेसिक आइडियाज है मैं आपको बताऊं सेकेंडरी
मेमोरी में फाइल को मैनेज करने के एक है हमारा कंटस एलोकेशन एक है लिंक्ड एलोकेशन और ये दोनों इतने और ऑर्थोडॉक्स मेथड है
मतलब पुराने मेथड है देर इज नथिंग न्यू ये लाइक अ एरे एरे लिंक लिस्ट एक तीसरा स्मार्ट अप्रोच भी है लाइक इंडेक्स
एलोकेशन हर किसी के कुछ एडवांटेज डिसएडवांटेज है मैं एक-एक करके आल गो वन बाय वन एंड देन आपको बात समझ आएगी पहले
देखते हैं कंटी के स लोकेशन तो देखो यहां पे हमने क्या किया है जैसे डिस्क में हम समझ रहे थे ना हमारे पास ट्रैक्स हैं हर
ट्रैक सेक्टर में डिवाइडेड उसको कुछ कैपेसिटी है उस तरह से नहीं देख रहे हम हमारे पास एक डिस्क है और उसको हमने ऐसा
ब्लॉक्स में डिवाइड करके रख लिया मतलब ऐसा विजुलाइज कर रहे हैं ब्लॉक नंबर 0 1 2 3 4 लाइक दिस ऐसे मैं 31 तक जा रहा हूं कंटी
केस लोकेशन क्या बोलता है लेकन एरे एक जगह से स्टार्ट करोगे और कंटस फैशन में आप फाइल बना सकते हो जैसे मेरे को यहां पर
नजर आ रहा है और साथ में डायरेक्ट्रीएंट्री नॉट लाइक डेटाबेस एडमिनिस्ट्रेटर तो आप
मेरे को स्टार्टिंग डिस्क ब्लॉक एड्रेस बताओगे आप मेरे को लेंथ बताओगे मैं आप आपको बता दूंगा या मैं आपको एंट्री कर
लूंगा 19 वाला देखो इसका नाम है मेल छह ब्लॉक है सो 1 2 3 4 5 6 लाइक दिस तो कंटस फैशन में आप डिस्क यहां पर इस्तेमाल करोगे
फाइल एलोकेट करोगे ऐसा करने का क्या एडवांटेज होगा एडवांटेज होगा कि फाइल एक्सेस करना बड़ा फास्ट होगा बेस अगर आपको
पता है तो सीधे आप किसी ब्लॉक पे जा सकते हो स्पीड होगी वही सारी पॉइंट डिसएडवांटेज फिर वही याद है अगर कंटस लोकेशन कर रहे यू
आर गोइंग टू सफर फ्रॉम एक्सटर्नल फ्रेगमेंटेशन अब जैसे यहां पर 1 2 3 4 5 6 7 88 9 10 11 12 13 14 15 15 ब्लॉक्स खाली
है मैं आपसे बोलूंगा एक काम करो कोई ऐसा फाइल स्टोर करके बताओ जिसमें एट ब्लॉक आधे मांग रहा हूं आप चला ही नहीं पाओगे क्यों
क्योंकि 15 ब्लॉक्स खाली तो है बट वो कंटीन्यूअसली अवेलेबल नहीं है एंड दैट बिकम अ क्लियर कट एग्जांपल ऑफ एक्सटर्नल
फ्रेगमेंटेशन और वो इतना सीवियर प्रॉब्लम है आपको याद है मेन मेमोरी में तो हमने पूरा पेजिंग सेगमेंटेशन कर डाला था उसके
लिए सो बड़ा प्रॉब्लम है इसके अंदर स्पीड है लेकिन मेमोरी में एफिशिएंट नहीं है कमिंग टू द नेक्स्ट आइडिया ये ों ही ये
दोनों वही पॉइंट लिखे हैं एडवांटेज एंड डिसएडवांटेज नाउ कमिंग टू द नेक्स्ट आइडिया वी हैव लिंकड एलोकेशन नाउ दिस
वर्क्स लाइक अ लिंक लिस्ट नॉन कंटस अप्रोच व मैं बोल रहा था दोनों बड़े बेसिक अप्रोच अब यहां पर क्या है एक फाइल है हमारे पास
जी स्टार्टिंग एड्रेस है नाइन अभी नाइन के बाद कहां जाना है तो दे यू सी यू विल हैव अ पॉइंटर नाइन कह रहा है 16 पे जाओ 16 कह
रहा है वन के पास जाओ वन कह रहा है इधर 10 के पास जाओ 10 कह रहा है 18 के पास जाओ 18 कह रहा है 25 -1 इज लाइक एन एग्जांपल ऑफ अ
इनवैलिड एड्रेस उसके आगे जाने की जरूरत नहीं है तो आप मुझे स्टार्टिंग बता दो वैसे तो एंड बताने की भी टेक्निकली जरूरत
नहीं है बट लिंकलिस्ट के साथ प्रॉब्लम है बीच में अगर कोई पॉइंटर गड़बड़ हो गया तो पता नहीं लगेगा कि डाटा लॉस भी हुआ कि
नहीं सो ऑन द सेफर साइड आप लेंथ बता दो या एंडिंग डीब बता दो तो मेरे को समझ आएगा अब लिंक लिस्ट के एडवांटेज क्या है अगेन क्या
यहां पे एक्सटर्नल फ्रेगमेंटेशन होगा जी नहीं अगर पूरे मेमोरी के अंदर कहीं पर भी ब्लॉक खाली है तो वो हम विद द हेल्प ऑफ़ अ
पॉइंटर लोकेट करा लेंगे वो कोई बड़ी बात नहीं है प्रॉब्लम यहां पर क्या होगा सर प्रॉब्लम होगा जब आप यू नो इसके ऊपर काम
करेंगे और समझेंगे कि मेरे को एक्सेस करना है तो देयर इज नो मेथड कि आप डायरेक्ट ब्लॉक नंबर फॉर एग्जांपल 18 के पास चले
जाओ आपको पूरा ट्रैवर्स करके जाना पड़ेगा व्हिच इज गोइंग टू मेक दिस आइडिया वेरी स्लो सो कंटस एलोकेशन में स्पीड है बट
मेमोरी एफिशिएंसी नहीं है इधर लिंक लिस्ट में मेमोरी एफिशिएंसी है देयर इज नो एक्सटर्नल फ्रेगमेंटेशन इधर स्पीड नहीं है
अभी मैं क्या चूज करूं सर मेरे को मेमोरी एफिशिएंसी भी चाहिए मेरे को स्पीड भी चाहिए सो व्हाट आई एम गोइंग टू डू इज अगेन
एडवांटेज डिसएडवांटेज आई विल पॉज य पूरा पैटर्न आपको मिल जाएगा आई विल गो फॉर इंडेक्स एलोकेशन जो कि बहुत कमाल का
कांसेप्ट है और ज्यादातर प्रैक्टिकल सिस्टम जो आज आप और मैं यूज़ करते हैं दे फॉलो इंडेक्स एलोकेशन व्हाट इज द आइडिया
समझाता हूं तो हम यहां पर क्या करते हैं कोई भी एक नोट लेते हैं जिसको बोलते हैं इंडेक्स ब्लॉक एक ब्लॉक लेते हैं इंडेक्स
ब्लॉक और यहां पर हम डाटा नहीं होल्ड करते थोड़ा लालच से बच हैं वी होल्ड द मेटा डाटा वैसे सिस्टम टू सिस्टम इंप्लीमेंटेशन
चेंज हो सकता है फिर भी एक बेसिक अंडरस्टैंडिंग है यह एक एग्जांपल है आई नोड का अब यहां पर क्या है हाफ पोर्शन ऑफ
दिस नोड अब यू नो कौन ओनर है जो भी मेटा डाटा क्या किसके पास क्या अथॉरिटी है कौन रीड कर सकता है राइट कर सकता है फाइल का
जितना डिटेलिंग है लास्ट मॉडिफाइड कब हुआ था उसका साइज क्या सब कुछ यहां पर लिखा है देन व्हाट वी आर गोइंग टू हैव इज वी आर
गोइंग टू हैव सम पॉइंट्स जिसको बोलते हैं डायरेक्ट ब्लॉक पॉइंट्स तो एक पॉइंटर आपको मिलेगा और वह पॉइंटर आपको कहां पहुंचाएगा
वो आपको एक ब्लॉक पे पहुंचाएगा जिस ब्लॉक में फाइनली डाटा लिखा हुआ है देन यहां पे एक और ऐसा पॉइंटर हो सकता है जो आपको एक
ऐसे ब्लॉक पे पहुंचाए जहां पे डाटा लिखा हुआ इससे होगा क्या इट इज लाइक मेरे पास लिंकलिस्ट की तरह बहुत सारे नोट्स हैं नॉन
कंटस फैशन में है बट मैं पहले नोट से दूसरे पे दूसरे से तीसरे पे नहीं जाता हूं मेरे पास जितने ब्लॉक्स है ना मैंने सबका
एड्रेस डायरेक्टली होल्ड करके रख लिया दिस इज द आइडिया इसको बोलते इंडेक्स एलोकेशन वही जो हमने पेजिंग में किया था वही जो हम
डीबीएमएस में करते हैं अब पेनल्टी तो लगेगी क्योंकि आपने सारे एड्रेस होल्ड करके रख ली बट एडवांटेज क्या है ये नॉन
कंटस भी है और मेरे को अगर लास्ट पे जाना है तो मेरे को पहले सब पे जाने की जरूरत नहीं है यूजिंग दिस पॉइंटर में डायरेक्टली
लास्ट पे जा सकता हूं इसकी प्रॉब्लम क्या है जो एक ब्लॉक है उसका साइज तो बड़ा स्पेसिफिक सा है क्या मैं उसमें इंफाइटिंग
सीवियरली लिमिट हो जाती है इसको कैसे सॉल्व करते हैं इसको सॉल्व करते हैं मल्टी लेवल ऑफ इंडेक्सिंग करके मतलब जैसे यहां
पे देख रहे हैं आप लिखा हुआ है सिंगल इनडायरेक्शन नाउ व्हाट डज दैट मीन इज मैं यहां पर एक एड्रेस होल्ड करूंगा जो मुझे
फर्द एक ब्लॉक के पास ले जाएगा एंड आई थिंक यू आर गेसिंग इट राइट जिस ब्लॉक में डाटा नहीं है उस ब्लॉक में अगेन एड्रेसस
ही रखे हुए हैं एंड देन दे आर गोइंग टू टेक यू टू द डाटा पार्ट बात समझ आ रही है तो मैं आपको लेके जाऊंगा एक ब्लॉक में
जिसमें फर्द एड्रेस उन एड्रेस में डटा प पहुंच व्हाट अबाउट डबल इनडायरेक्शन इससे काम ना चले तो मैं आपको एक ब्लॉक तक लेक
जाऊंगा उस ब्लॉक में आपको डेटा नहीं एड्रेस मिलेंगे वो एड्रेस जिन ब्लॉक तक लेके जाएंगे उनमें भी एड्रेस मिलेगा एंड
देन दोज एड्रेसस आर गोइंग टू पॉइंट टू डाटा और उसका कोई एंड नहीं है जैसे इसने डायग्राम में लिखा नहीं बट दे इज अ ट्रिपल
इनडायरेक्शन थिंग सो एड्रेस एड्रेस एड्रेस एंड डाटा और ये सब भी मल्टीपल हो सकते हैं यू कैन हैव थ्री इनडायरेक्ट एड्रेसस फोर
डबल इंड 15 ट्रिपल इनडायरेक्शन समथिंग लाइक दिस तो जो एक अगर डिसएडवांटेज था कि फाइल का कैपेसिटी बहुत सीवियरली लिमिट था
वो भी हमने हटा दिया सो दिस इज द आइडिया इतना डायग्राम आप एग्जाम में बना के आ जाओगे कहानी खत्म पैसा मु हजम हो जाएगा सर
मामला एकदम सेट हो जाएगा तो दोनों एडवांटेजेस हैं मेमोरी एफिशिएंसी काफी हद तक है क्योंकि एक्सटर्नल फ्रेगमेंटेशन ये
थोड़ा मेटा डाटा में जरूर वेस्ट होगा बट वो तो यू नो दैट इज पार्ट एंड पार्सल ऑफ द स्टोरी एंड सेकंड थिंग इज कि क्यों नॉन
कंटस है तो मेमोरी एफिशिएंसी और क्योंकि सबको एक्सेस नहीं करना तो स्पीड भी यहां पर काइंड ऑफ हमारी फास्ट हो जाती है तो यह
कहानी इंडेक्स एलोकेशन की नाउ गोइंग फॉरवर्ड एक और छोटा सा टॉपिक यहां पर हमारे पास है जिसको हम बोलते हैं क्या
फ्री स्पेस मैनेजमेंट ओके नाउ टॉकिंग अबाउट फ्री स्पेस मैनेजमेंट यह भी एक छोटा सा कांसेप्ट है क्वेश्चन पूछा जा सकता है
एक बार डिटेल में बात करनी जरूरी है आईडिया क्या है सर आईडिया यह है कि ऑपरेटिंग सिस्टम का एक ड्यूटी है कि जितने
भी फ्री स्पेसेस हैं उसकी संपत्ति है ना ये उस स्पेस को उसको भी पूरी तरह मैनेज करके अपने पास रखना है है ना बड़ा
इंपॉर्टेंट पॉइंट है अभी जो फ्री स्पेस मैनेजमेंट है इसके बहुत सारे अप्रोचेबल क्स है जिस तरह से हम उसे
इमेजिन कर रहे हैं यह जो शेडेड ब्लॉक्स है ये ब्लॉट्स ऑक्यूपाइड है तो ये कहीं ना कहीं हमारी बुक्स में लिखे एंट्री में
लिखे हुए हैं कि ये फिलहाल किसके पास है ब जो खाली ब्लॉक्स हैं उनको मैनेज करना बहुत जरूरी ताकि नेक्स्ट टाइम जब कोई स्पेस
रिक्वायर करे है ना तो उसको लोकेट किया जा सके तो क्या-क्या अपोजेस है आई विल गो वन बाय वन अगेन एक सबसे सिंपलेस्ट अप्रोच जो
भी हमने समझा इज लाइक अ लिंक लिस्ट सो व्हाट यू कैन हैव इज मेरे पास एक लिंक लिस्ट है अच्छा यहां पर शायद हमने उल्टा
दिखाया फ्री है शेड वाले फ्री हैं जो वाइट है वो ऑक्यूपाइड है तो मेरे पास एक पॉइंटर एंड विद द हेल्प ऑफ पॉइंटर जितने भी एमटी
ब्लॉक्स हमारे पास हैं उसको हम होल्ड करके रखेंगे लिंक लिस्ट से तो लिंक लिस्ट का एडवांटेज अगेन यही है कि कहीं पर भी ब्लॉक
होगा पहली बात तो मैं उसको होल्ड कर लूंगा उसको पकड़ लूंगा ये एक्सेस कंटीन्यूअस हो बिल्कुल भी जरूरी नहीं है सेकंड एक
एडवांटेज जो आमतौर पे डिसएडवांटेज होता है यहां पे नहीं है लिंकलिस्ट हम बोलते हैं यार एक्सेस बड़ा स्लो है बट मेरे को तो
एमटी ब्लॉक चाहिए ना तो क्या ये जरूरी है कि मेरे को 13 नंबर पे ही जाना भाई क्यों जाना है तेरे को 13 नंबर पे अगर कोई
बोलेगा एक डिस्क ब्लॉक चाहिए जो सबसे पहले एमटी होगा उसको उठा के लोकेट कर दो आप आगे चले जाओ कोई बोलेगा चार और चाहिए तो 1
दोती चार तो हमेशा जो शुरुआत के एमटी ब्लॉक्स होंगे उनको आप इस्तेमाल कर सकते हो पूरी लिस्ट को एक्सेस करने की कोई
जरूरत नहीं है तो ये एक अप्रोच है इसमें थोड़ा सा प्रॉब्लम ये है लिंकलिस्ट के थ्रू मैनेज करते हैं ना तो रिलायबिलिटी
अगर बीच में एक भी पॉइंटर गड़बड़ हुआ तो पूरी लिंकलिस्ट मिस मैनेज हो सकती है है ना तो एक एक और थॉट प्रोसेसेस पर काम करने
का वो क्या है वो है बिट वेक्टर अप्रोच और मैं भी आपको समझाऊ मेन मेमोरी के केस में यह सारा का सारा स्पेस इंफॉर्मेशन एक जगह
नहीं है मेरे पास कितना स्पेस अगर मान लीजिए मैं आपसे बोलता हूं मेरे को एक फाइल स्टोर करानी है कंटस एलोकेशन चाहिए फॉर
एग्जांपल फाइल की नीड है और 10 ब्लॉक कंटीन्यूअस चाहिए इस मैकेनिज्म से ये नहीं समझ आता कि ये 10 ब्लॉक कंट केशन नॉन कंट
केशन मेमोरी में कहां पे है एक और पॉपुलर अप्रोच है इज कॉल्ड बिट वेक्टर अप्रोच अब ये अप्रोच क्या करता है जितने भी ब्लॉक्स
हमारे पास अभी ये जो डायग्राम देख रहे थे एक एरे हम बनाते हैं एंड हाउ मेनी ब्लॉक्स आर देयर 31 अच्छा यहां 15 तक ही हमने
एग्जांपल लिया है तो देर देर देयर इज अ वन बिट एसोसिएटेड विद एवरी ब्लॉक एंड एज यू कैन सी अगर वहां पे मैं जरो भरता हूं इसका
मतलब ब्लॉक अभी ऑक्यूपाइड है अगर वहां पर मैं वन भरता हूं इसका मतलब ब्लॉक्ड फ्री ब्लॉक फ्री है तो मैं एक्चुअली ब्लॉक पे
जाके लिंक लिस्ट नहीं बना रहा मुरे को कोई पूरा ट्रैवर्सल नहीं करना मैं तो यहीं से जरक डा के देख लेता हूं अगर आपको मेरे को
पूछना है कि बताओ भाई कितना अ ब्लॉक्स खाली है मैं जाके देख लूंगा कितने वन है आपको मेरे को पूछना बताओ कंक्यूबिन कहां
मिलेंगे मैं देख लूंगा कंकूट चार बार वन कहां रहा है समथिंग लाइक दिस तो बिट वेक्टर है बहुत पॉपुलर अप्रोच है जिसके
थ्रू मैनेज करते हैं हालांकि इन द लंगर रन आपको लग रहा होगा कि हर ब्लॉक के लिए एक बिट है तो बहुत सस्ता है जैसे-जैसे मेमोरी
कैपेसिटी बढ़ती है इसकी कॉस्टिंग बढ़ती जाती है जस्ट टू कोट एन एग्जांपल अगर कोई डिस्क है जिसका साइज है 1 टेराबाइट जो आज
के टाइम प बहुत अजीब बात नहीं है 1 टेराबाइट की हार्ड डिस्क है उसका बिट वेक्टर अप्रोच से टोटल जो कॉस्टिंग आती है
वो आती है 256 एब और अगर इतना स्पेस आप रैम में रखेंगे हालांकि रैम भी आजकल अच्छी-अच्छी रैम आने लगी है सिस्टम में
8gb 16gb बट स्टिल 256 एब इज अ हेल आउट ऑफ रिक्वायरमेंट और इसका पूरा मजा आपको तभी मिलेगा जब ये पूरा मैप मेन मेमोरी में
होगा तभी आप इसको पढ़ पाएंगे तो अगेन हर अप्रोच के कुछ एडवांटेज डिसएडवांटेज है वो डिपेंड यही करता है कि हमारा सिस्टम कैसे
बिहेव कर रहा है उसका क्या स्केल है और उस सिस्टम में क्या सूट करेगा यस तो यह एक आईडिया था हमारा कि कैसे हम अपना फ्री
स्पेस मैनेज कर सकते हैं ओके नाउ कमिंग टू द लास्ट टॉपिक ऑफ दिस वीडियो एंड अभी भी आप में से जो लोग बने हुए हैं कमाल का मज़
आ गया है है ना अ लास्ट इज़ फाइल ऑर्गेनाइजेशन वैसे दिस इज़ नॉट अ टॉपिक जो आमतौर पे मैंने कहीं इंटरव्यूज में
कॉम्पिटेटिव एग्जाम में कहीं देखा हो इवन इन यूनिवर्सिटीज इट इज़ नॉट दैट इंपॉर्टेंट तो यह थोड़ा सा याद करने वाले
अप्रोच है कांसेप्चुअल आइडियाज काइंड ऑफ़ मैं ऑलरेडी डिस्कस कर चुका हूं तो यू कैन टेक अ स्क्रीनशॉट ऑल द पॉइंट जो मैं मैंने
फेयरली लिखे हैं तो फाइल ऑर्गेनाइजेशन की अगर मैं फंडामेंटल बात करूं सीक्वेंशियल लाइक अ एरे आप मैनेज कर सकते हैं कंटस
होगा एक्सटर्नल फ्रेगमेंटेशन होगा वही सारे पॉइंट्स हैं वी कैन हैव रैंडम और डायरेक्ट ऑर्गेनाइजेशन जहां पे अगेन हमने
कहीं भी होल्ड करके रखा होगा उनके पॉइंट्स हमारे पास होंगे लाइक दिस और की के थ्रू हम एक्सेस करेंगे सीरियल फाइल
ऑर्गेनाइजेशन एंड इंडेक्स सीक्वेंशियल फाइल ऑर्गेनाइजेशन मेथड सो मैं एक-एक पॉइंट एक्सप्लेन नहीं कर रहा आई डोंट थिंक
इट इज दैट इंपॉर्टेंट व्हाट यू कैन डू यू कैन टेक अ स्क्रीनशॉट या जो नोट्स है बाद में आप एक्सेस कर सकते हो इफ
समबे आंसर करके आओगे अभी जो चीज मैंने मैनेज की फिर उसी को दोबारा देखिए है एक्सेस मेथड तो तीन
अप्रोचेबल जिक तो सीक्वेंशियल लाइक अ लिंकलिस्ट यू गो डायरेक्ट अगेन अगर बेस एड्रेस है आप डायरेक्ट पहुंच सकते हैं
कंटीन्यूअस फैशन में और इंडेक्स एलोकेशन आपको पता है जितना भी हमारे पास इंफॉर्मेशन है हर किसी का डायरेक्ट पॉइंटर
आपके पास अगर है देन दैट विल बी इंडेक्स एलोकेशन टॉकिंग अबाउट डायरेक्ट्रीएंट्री
एक बड़ी डायरेक्ट्रीएंट्री तरह यहां पर वी कैन हैव डिफरेंट डिफरेंट फोल्डर्स मे बिलोंग टू डिफरेंट यूजर्स एंड
देन ऑन द नेक्स्ट लेवल इसमें कितने भी लेवल ऑफ डायरेक्टरीज हो सक सते एंड देन यूजिंग दिस मेथड आप अपनी फाइल्स को
ऑर्गेनाइज कर सकते हो अगेन वही लिखा है लाइक अ फोल्डर टर्मिनोलॉजी वही सारे पॉइंट है कौन-कौन से बेसिक ऑपरेशंस हैं जो
परफॉर्म किए जा सकते हैं क्रिएट डायरेक्ट्रीएंट्री बार सेमेस्टर्स में पूछा गया है तो मैंने
यह एक पॉइंटेड डिफरेंस भी लिख दिया है सिंगल लेवल डायरेक्ट्रीएंट्री बेस्ड ऑन सम क्राइटेरियास तो इसको आप चेक
आउट कर सकते हैं अ क्यों नेसेसरी ऑर्गेनाइजेशन करना क्या फीचर्स है मेटा डाटा डायनेमिक नेचर अगेन यू कैन हैव अ नोट
टू दीज पॉइंट्स मैं बोल रहा हू दीज आर नॉट दैट इंपॉर्टेंट अगेन मैंने कहीं देखा कि एक एग्जांपल में अलग से पूछा है उसने
डिफरेंस तो यहां पर आप देख सकते हैं सीक्वेंशियल फाइल एंड इंडेक्स फाइल सो वी हैव अ सेपरेट डिफरेंस टू दिस यह है एक और
छोटा सा पॉइंट है कि फाइल प्रोटेक्शन सिस्टम ऑपरेटिंग सिस्टम का रिस्पांसिबिलिटी फाइल आर इंपॉर्टेंट थिंग
तो कौन-कौन से फीचर हैं अगेन जैसे सॉफ्टवेयर के फीचर पढ़ते हैं ना रिलायबिलिटी सिक्योरिटी कंट्रोल्ड एक्सेस
एक्सेस कंट्रोल ऑल दीज आर फाइल प्रोटेक्शन फीचर्स एक्सेस मैट्रिक्स उसको इंफॉर्मेशन को रिप्रेजेंट करने के अलग-अलग तरीके
कितने यूजर है कितनी फाइल है कौन से यूजर को किस फाइल पे क्या परमिशन है सो यू कैन हैव दिस काइंड ऑफ अ मैट्रेस जहां पे बोल
रहा है फाइल ए है यूजर वन है यू हैव अ रीड राइट अथॉरिटी फाइल बी यू हैव रीड अथॉरिटी फाइल सी यू हैव नथिंग तो यू कैन हैव अ
मैट्रिक्स टू दिस आप लिस्ट भी बना सकते हैं फाइल ए कितने यूजर हर यूजर की क्या-क्या परमिशन यू कैन राइट दिस डाउन अ
कैपेबिलिटी लिस्ट उसको और थोड़ा सा डिफरेंट तरह से यूजर के हिसाब से इंस्टेड ऑफ फाइल के हिसाब से यूजर के हिसाब से आप
मैनेज कर सकते हैं तो देयर आर डिफरेंट मेथड्स यूजिंग वच एंड अगर सिस्टम बहुत बड़ा है यूजर बहुत कम है अगेन स् पार्स
मैट्रिक्स वही जहां पे इंफॉर्मेशन बहुत कम होती है तो बजाय पूरा मैट्रिक्स बनाने के दिस इज अ बेटर अप्रोच है ना वरना इतनी
बड़े मैट्रिक्स में हो सकता है आपके पास दो ही फाइल एक्सेस करने का परमिशन हो दैट इज इट इंप्लीमेंटेशन अगेन जैसे आप
चाहे वैसे इस मेथड को इंप्लीमेंट कर सकते हैं दो तीन मैकेनिज्म यहां पर लिखे हुए हैं सो दिस वास टोटली फन पहली बार हमने
अटेंप्ट किया एंड अभी मैंने टोटल टाइम कैलकुलेट भी नहीं किया कुछ मेरे ख्याल से चार पाच घंटे के करीब होगा बहुत मेहनत की
है और ऐसा करने की चाहा है आगे और इस परे डिटेल में काम करें पूरी तरह से कप्शन बहुत इंपॉर्टेंस इसलिए रखता है वैसे
सब बोलते हैं बट इंपॉर्टेंस इसलिए रखता है कि यार जस्टिफिकेशन मिलता है अकेलो स्टूडियो में चिल्लाना कभी कभी बहुत अजीब
हो जाता है बट जब आप लोग के नंबर्स आते हैं ना तो वही एक हमारे पास फीडबैक है अभी भी फोन से निकल के तो या कैमरा से निकल के
आप मुझे नहीं बोल सकते अच्छा मजा आ रहा है तो वो एक सेंस ऑफ मोटिवेशन मिलता है तो प्लीज वो जरूर करिए गिव मी अ कमेंट कि कौन
से टॉपिक्स हैं जो चार पांच छह इंपॉर्टेंट सब्जेक्ट है वो तो हम करेंगे करेंगे इस पैटर्न में और कौन से सब्जेक्ट है जो आपके
सेमेस्टर्स में नया आया मेरे को बताओ आई विल डू दैट यू नो बिग वीडियो खत्म कर देंगे उसको तो कमेंट करके बताओ इसी तरह
अपना साथ देते रहिए आप ही के साथ ने यहां तक पहुंचाया और इसको और आगे भी कंटिन्यू करते रहेंगे भगवान आप सभी को खुश रखे जय
हिंद जय भारत
Heads up!
This summary and transcript were automatically generated using AI with the Free YouTube Transcript Summary Tool by LunaNotes.
Generate a summary for freeRelated Summaries

Introduction to Operating Systems: Functions, Types, and Importance
This lecture provides a comprehensive introduction to operating systems, explaining their functions, types, and significance in computer science. It covers the role of operating systems as intermediaries between users and hardware, and highlights popular operating systems like Windows, Linux, and Android.

Understanding Operating System Structures: A Comprehensive Overview
This lecture delves into the various structures of operating systems, including simple, monolithic, layered, microkernel, and modular approaches. Each structure is analyzed for its advantages and disadvantages, providing a clear understanding of how operating systems are designed and function.

Understanding Operating System Design and Implementation
This lecture explores the complexities of operating system design and implementation, focusing on defining goals, user and system requirements, and the importance of separating mechanisms from policies. It also discusses the advantages of using higher-level programming languages for OS development.

Comprehensive Guide to Object-Oriented Programming (OOP) in C++
This video provides an in-depth exploration of Object-Oriented Programming (OOP) concepts in C++, covering everything from basic definitions to advanced implementations. It includes practical examples, coding demonstrations, and multiple-choice questions to reinforce understanding, making it an essential resource for students preparing for internships and placements.

Understanding System Calls: An Overview of User Mode and Kernel Mode
This lecture provides a comprehensive overview of system calls, explaining their role as an interface to operating system services. It discusses the differences between user mode and kernel mode, the process of context switching, and illustrates the concept of system calls through a practical example of copying file contents.
Most Viewed Summaries

Mastering Inpainting with Stable Diffusion: Fix Mistakes and Enhance Your Images
Learn to fix mistakes and enhance images with Stable Diffusion's inpainting features effectively.

A Comprehensive Guide to Using Stable Diffusion Forge UI
Explore the Stable Diffusion Forge UI, customizable settings, models, and more to enhance your image generation experience.

How to Use ChatGPT to Summarize YouTube Videos Efficiently
Learn how to summarize YouTube videos with ChatGPT in just a few simple steps.

Ultimate Guide to Installing Forge UI and Flowing with Flux Models
Learn how to install Forge UI and explore various Flux models efficiently in this detailed guide.

How to Install and Configure Forge: A New Stable Diffusion Web UI
Learn to install and configure the new Forge web UI for Stable Diffusion, with tips on models and settings.