अन्य उत्तर ओवरसिम्प्लीफिकेशन हैं, प्रत्येक कहानी के कुछ हिस्सों को प्रस्तुत करते हैं, और कुछ बिंदुओं पर गलत हैं।
कार्य निर्देशिका को ट्रैक करने के दो तरीके हैं :
- हर प्रक्रिया के लिए, उस प्रक्रिया का प्रतिनिधित्व करने वाले कर्नेल-स्पेस डेटा संरचना में, कर्नेल दो vnode संदर्भों को कार्यशील निर्देशिका के vnodes और उस प्रक्रिया के रूट निर्देशिका के लिए संग्रहीत करता है। पूर्व संदर्भ द्वारा
chdir()
और fchdir()
बाद में सिस्टम कॉल द्वारा सेट किया गया है chroot()
। एक उन्हें परोक्ष रूप से /proc
लिनक्स ऑपरेटिंग सिस्टम पर या fstat
FreeBSD पर कमांड के माध्यम से और इस तरह देख सकते हैं:% fstat -p $$ | हेड-एन 5
USER CMD PID FD MOUNT INUM MODE SZ | DV R / W
जेडेबीपी ज़श 92648 टेक्स्ट / 24958 -आर-एक्सआर-एक्सआर-एक्स 702360 आर
जेडीबीपी ज़श 92648 शेट्टी / देव 148 करोड़ - w ---- पीटीएस / 4 आरडब्ल्यू
JdeBP zsh 92648 wd / usr / home / JdeBP 4 drwxr-xr-x r
JdeBP zsh 92648 रूट / 4 drwxr-xr-x 35 आर
%
जब पथनाम रिज़ॉल्यूशन संचालित होता है, तो यह उन संदर्भित vnodes में से एक या दूसरे पर शुरू होता है, चाहे वह मार्ग सापेक्ष हो या निरपेक्ष। ( …at()
सिस्टम कॉल का एक परिवार है जो एक ओपन (डायरेक्टरी) फ़ाइल डिस्क्रिप्टर द्वारा तीसरे विकल्प के रूप में संदर्भित vnode पर आरंभ करने के लिए मार्गनाम रिज़ॉल्यूशन की अनुमति देता है।)
माइक्रो कर्नेल में डेटा संरचना अनुप्रयोग स्थान में है, लेकिन इन निर्देशिकाओं के लिए खुला संदर्भ रखने का सिद्धांत समान है।
- आंतरिक रूप से, Z, Korn, Bourne Again, C और Almquist शेल जैसे गोले के भीतर, शेल अतिरिक्त रूप से आंतरिक स्ट्रिंग चर के स्ट्रिंग हेरफेर का उपयोग करके कार्य निर्देशिका का ट्रैक रखता है। जब भी यह कॉल करने का कारण होता है तो यह ऐसा करता है
chdir()
।यदि कोई सापेक्ष पथनाम में बदलता है, तो यह उस नाम को जोड़ने के लिए स्ट्रिंग में हेरफेर करता है। यदि कोई एक पूर्ण पथनाम में बदलता है, तो वह स्ट्रिंग को नए नाम से बदल देता है। दोनों ही मामलों में, यह स्ट्रिंग को हटाने .
और ..
घटकों को समायोजित करता है और प्रतीकात्मक लिंक को उनके लिंक्ड-इन नामों के साथ बदलने का पीछा करता है। ( उदाहरण के लिए, यहाँ Z शेल कोड है ।)
आंतरिक स्ट्रिंग चर में नाम एक शेल चर नाम से ट्रैक किया जाता है PWD
(या cwd
सी शेल में)। यह पारंपरिक रूप से एक पर्यावरण चर (नाम PWD
) के रूप में शेल द्वारा उत्पन्न कार्यक्रमों के लिए निर्यात किया जाता है ।
चीजों को ट्रैक करने की ये दो विधियाँ निर्मित और शेल कमांडों के विकल्पों -P
और -L
विकल्पों द्वारा cd
और pwd
शेल के बिल्ट-इन pwd
कमांड्स और दोनों कमांड्स और /bin/pwd
बिल्ट-इन pwd
कमांड्स जैसे कि (अन्य के बीच) के अंतर से पता चलती हैं। VIM और NeoVIM।
% mkdir a; ln -sab
% (cd b; pwd; / bin / pwd; printenv PWD)
/ Usr / घर / JdeBP / b
/ Usr / घर / JdeBP / एक
/ Usr / घर / JdeBP / b
% (cd b; pwd -P; / बिन / pwd -P)
/ Usr / घर / JdeBP / एक
/ Usr / घर / JdeBP / एक
% (cd b; pwd -L; / bin / pwd -L)
/ Usr / घर / JdeBP / b
/ Usr / घर / JdeBP / b
% (cd -P b; pwd; / bin / pwd; Printenv PWD)
/ Usr / घर / JdeBP / एक
/ Usr / घर / JdeBP / एक
/ Usr / घर / JdeBP / एक
% (cd b; PWD = / hello / there / bin / pwd -L)
/ Usr / घर / JdeBP / एक
%
जैसा कि आप देख सकते हैं: "लॉजिकल" वर्किंग डायरेक्टरी प्राप्त करना PWD
शेल वेरिएबल (या एनवायरनमेंट वेरिएबल अगर कोई शेल नहीं है) को देखने का विषय है; "फिजिकल" वर्किंग डायरेक्टरी प्राप्त करने के दौरान getcwd()
लाइब्रेरी फ़ंक्शन को कॉल करने का विषय है ।
/bin/pwd
जब -L
विकल्प का उपयोग किया जाता है तो कार्यक्रम का संचालन कुछ सूक्ष्म होता है। यह पर्यावरण चर के मूल्य पर भरोसा नहीं कर सकता हैPWD
जो इसे विरासत में मिला है। आखिरकार, इसे एक शेल द्वारा लागू करने की आवश्यकता नहीं है और हस्तक्षेप करने वाले कार्यक्रमों ने शेल के तंत्र को लागू नहीं किया हो सकता है ताकि PWD
पर्यावरण चर हमेशा काम करने वाले निर्देशिका के नाम को ट्रैक कर सके। या कोई ऐसा कर सकता है जो मैंने वहीं किया था।
तो यह क्या करता है (जैसा कि POSIX मानक कहता है) यह जांचें कि नाम में दिया गया नाम PWD
एक ही चीज़ का नाम देता है .
, जैसा कि सिस्टम कॉल ट्रेस के साथ देखा जा सकता है:
% ln -sac
% (cd b; ट्रस / बिन / pwd -L 3> & 1 1> & 2 2> & 3 | grep -E '^ स्टेट | __getcwd')
स्टेट ("usr / home / JdeBP / b", { mode = drwxr-xr-x, inode = 120932, size = 2, blksize = 131072}) = 0 (0x0)
स्टेट ("।", {mode = drwxr-xr-x, inode = 120932, size = 2, blksize = 131072}) = 0 (0x0)
/ Usr / घर / JdeBP / b
% (cd b; PWD = / usr / local / etc ट्रस / बिन / pwd -L 3> और 1 1> & 2 2> & 3 | grep -E '^ स्टेट | __getcwd':
"" / usr / local / etc " , {विधा = drwxr-xr-x, inode = 14835, size = 158, blksize = 10240}) = 0 (0x0)
स्टेट ("।", {मोड = drwxr-xr-x, इनोड = 120932, आकार = 2 , blksize = 131072}) = 0 (0x0)
__getcwd ("/ usr / होम / JdeBP / a", 1024) = 0 (0x0)
/ Usr / घर / JdeBP / एक
% (cd b; PWD = / hello / there truss / bin / pwd -L 3> & 1 1> & 2 2> & 3 | grep -E '^ stat | __getcwd')
stat ("/ hello / there", 0x7fffffe73030) ERR # 2 'ऐसी कोई फ़ाइल या निर्देशिका'
__getcwd ("/ usr / home / JdeBP / a", 1024) = 0 (0x0)
/ Usr / घर / JdeBP / एक
% (cd b; PWD = / usr / home / JdeBP / c truss / bin / pwd -L 3> & 1 1> & 2 2> & 3 | grep -E '^ स्टेट | __getwwd')
स्टेट ("/ usr / home / home /" JdeBP / c ", {mode = drwxr-xr-x, inode = 120932, size = 2, blksize = 131072}) = 0 (0x0)
स्टेट ("। ", {मोड} drwxr-xr-x, इनोड = 120932। , आकार = 2, blksize = 131072}) = 0 (0x0)
/ Usr / घर / JdeBP / सी
%
जैसा कि आप देख सकते हैं: यह केवल कॉल करता है getcwd()
अगर यह एक बेमेल का पता लगाता है; और इसे PWD
एक स्ट्रिंग पर सेट करके बेवकूफ बनाया जा सकता है जो वास्तव में एक ही निर्देशिका का नाम देता है, लेकिन एक अलग मार्ग से।
getcwd()
पुस्तकालय समारोह अपने आप में एक विषय है। लेकिन précis:
..
फिर से नेविगेट करना अपने आप में एक विषय है। एक और précis: हालांकि निर्देशिकाएं पारंपरिक रूप से (यद्यपि, जैसा कि पहले से ही बताया गया है, इसकी आवश्यकता नहीं है) ..
डिस्क पर निर्देशिका डेटा संरचना में वास्तविक है, कर्नेल प्रत्येक निर्देशिका के मूल निर्देशिका को ट्रैक करता है जो स्वयं vnode है और इस प्रकार ..
किसी भी vnode में नेविगेट कर सकता है कार्यकारी डाइरेक्टरी। यह माउंटपॉइंट और परिवर्तित रूट तंत्र द्वारा कुछ जटिल है, जो इस उत्तर के दायरे से परे हैं।
अलग
Windows NT वास्तव में एक समान काम करता है। एक कार्यशील प्रति निर्देशिका है, जो SetCurrentDirectory()
एपीआई कॉल द्वारा निर्धारित की जाती है और कर्नेल द्वारा उस निर्देशिका में एक (आंतरिक) ओपन फाइल हैंडल के माध्यम से प्रति प्रक्रिया ट्रैक की जाती है; और पर्यावरण चर का एक सेट है जो Win32 प्रोग्राम (न केवल कमांड इंटरप्रेटर्स, बल्कि सभी Win32 प्रोग्राम्स) कई वर्किंग डाइरेक्टरीज़ (एक प्रति ड्राइव) के नामों को ट्रैक करने के लिए उपयोग करते हैं, जब भी वे डायरेक्टरी बदलते हैं या उन्हें अधिलेखित करते हैं।
परंपरागत रूप से, यूनिक्स और लिनक्स ऑपरेटिंग सिस्टम के मामले के विपरीत, Win32 प्रोग्राम इन पर्यावरण चर को उपयोगकर्ताओं के लिए प्रदर्शित नहीं करते हैं। एक व्यक्ति कभी-कभी विंडोज एनटी पर चलने वाले यूनिक्स जैसे सबसिस्टम में उन्हें देख सकता है, हालांकि, साथ ही साथ SET
एक विशेष तरीके से कमांड दुभाषियों के आदेशों का उपयोग करके भी ।
आगे की पढाई