a.out
उबंटू टर्मिनल का उपयोग करते हुए , सी प्रोग्राम को निष्पादित करते समय , मुझे केवल लिखने के बजाय हमेशा ./
पहले टाइप करने की आवश्यकता क्यों है ? क्या इसका कोई हल है?a.out
a.out
a.out
उबंटू टर्मिनल का उपयोग करते हुए , सी प्रोग्राम को निष्पादित करते समय , मुझे केवल लिखने के बजाय हमेशा ./
पहले टाइप करने की आवश्यकता क्यों है ? क्या इसका कोई हल है?a.out
a.out
जवाबों:
जब आप किसी प्रोग्राम का नाम टाइप करते हैं जैसे a.out
कि सिस्टम आपके PATH में फाइल की तलाश करता है। मेरे सिस्टम पर, PATH सेट है
/usr/lib/lightdm/lightdm:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games
तुम्हारा भी शायद ऐसा ही है। जांच करने के लिए, echo $PATH
एक टर्मिनल में दर्ज करें ।
सिस्टम दिए गए आदेश में इन निर्देशिकाओं के माध्यम से देखता है और अगर यह नहीं मिल सकता है तो प्रोग्राम एक command not found
त्रुटि पैदा करता है ।
कमांड को ./
प्रभावी ढंग से प्रस्तुत करते हुए कहते हैं "पाथ के बारे में भूल जाओ, मैं चाहता हूं कि आप केवल वर्तमान निर्देशिका में दिखें"।
इसी तरह आप सिस्टम को केवल किसी अन्य विशिष्ट स्थान पर देखने के लिए कह सकते हैं, जैसे कि किसी रिश्तेदार या निरपेक्ष मार्ग के साथ कमांड को प्रस्तुत करना:
../
मूल निर्देशिका में इसका अर्थ है जैसे मूल निर्देशिका ../hello
में हैलो की तलाश करें।
./Debug/hello
: " hello
मेरी वर्तमान निर्देशिका के डीबग उपनिर्देशिका में देखें।"
या /bin/ls
: " ls
निर्देशिका में देखें /bin
"
डिफ़ॉल्ट रूप से, वर्तमान निर्देशिका पथ में नहीं है क्योंकि इसे सुरक्षा जोखिम माना जाता है। देखें क्यों है डिफ़ॉल्ट रूप से पथ में नहीं है? क्यों के लिए Superuser पर
वर्तमान निर्देशिका को आपके PATH में जोड़ना संभव है, लेकिन लिंक किए गए प्रश्न में दिए गए कारणों के लिए, मैं इसकी सिफारिश नहीं करूंगा।
.
PATH
.
यहाँ कुछ खास नहीं है, आप एक पूर्ण या रिश्तेदार पथ का उपयोग कर सकते हैं जैसे निष्पादन योग्य /home/user/foo/a.out
या./build/a.out
.
में विशेष है क्योंकि इसका मतलब है "मेरी वर्तमान निर्देशिका" इसलिए कोई भी निर्देशिका हो सकती है जो उपयोगकर्ता उन्हें पढ़ने और विशेषाधिकारों को निष्पादित करने में स्वयं को पाता है। यह एक विशिष्ट पूर्ण योग्य पथ को जोड़ने की तुलना में संभावित रूप से अधिक खतरनाक है।
.
कोई विशेष स्थिति नहीं रखता है, यह सिर्फ एक रास्ता है जो बस के साथ शुरू हो सकता है /
और ./blah
बस के साथ cat
या grep
बैश प्रॉम्प्ट के साथ काम करेगा ।
इतना सरल होने का कारण।
मान लीजिए कि आपके पास वर्तमान निर्देशिका में एप्लिकेशन के समान नाम वाला एक कमांड है। फिर शेल में कमांड चलाने से बिल्ट-इन कमांड के बजाय आपके ऐप को इनवॉइस किया जाएगा । यह एक सुरक्षा चिंता का विषय होगा अगर कुछ और नहीं।
./
सामने उपयोग करने की आवश्यकता होने पर, शेल जानता है कि आप दिए गए नाम के साथ आवेदन को निष्पादित करना चाहते हैं, न कि उस नाम के साथ अंतर्निहित कमांड।
./
उन फ़ाइलों को निष्पादित करता है जो आपके में नहीं हैं $PATH
, बल्कि यह फ़ाइल को वर्तमान निर्देशिका (या किसी अन्य ./home/stefano/script.sh
) के माध्यम से निष्पादित करती है । अब, पीएटीएच एक पर्यावरण चर है जिसमें सभी स्थानों पर बैश निष्पादन योग्य कार्यक्रमों की तलाश कर सकते हैं, उनके लिए पूर्ण (पूर्ण) पथ के बिना।
गलत फ़ाइल चलाने से बचने के लिए इस पृथक्करण की आवश्यकता है। यानी अगर आपके पास ls
अपने घर निर्देशिका में एक फ़ाइल है , तो यह आपके PATH में नहीं होने के कारण इसे असली के साथ भ्रमित करने से रोक देगा ls
। पथ परिवर्तन खोज क्रम को भी परिभाषित करता है:
exec
सिसकॉल बनाने की कोशिश करता है (कर्नेल की एक विशेष विधि, प्रोग्राम कैसे शुरू किए जाते हैं), सिस्टम आपके पीएटीएच में प्रत्येक निर्देशिका के माध्यम से जाकर फाइल की तलाश करता है। एक बार प्रोग्राम मिल जाने के बाद, भले ही यह कई निर्देशिकाओं में हो, खोज बाधित होती है और पहले पाया गया भाग चलता है।फ़ाइल चलाने के लिए, आपको निष्पादन योग्य बिट को अनुमतियों में सेट करना होगा:
चूंकि आप पहले से ही कमांड लाइन पर हैं, आप बस टाइप कर सकते हैं chmod +x finename
।
या आप फ़ाइल को राइट क्लिक करके और गुण का चयन करके अनुमतियाँ सेट कर सकते हैं :
अब आप PATH में किसी भी निर्देशिका में फ़ाइल को कॉपी कर सकते हैं, यह देखने के लिए कि कौन-कौन से लोग वहां हैं - और वे प्रति उपयोगकर्ता आधार पर सेट हैं - टाइप echo $PATH
।
stefano@3000-G530:~$ echo $PATH
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games
यदि आप एक निष्पादन योग्य फ़ाइल बनाते हैं cat
, और इसे स्थानांतरित करते हैं /usr/local/sbin
, तो इसे उचित के बजाय चलाया जाता है cat
, जो अंदर रहता है /bin
। आप पता लगा सकते हैं, जहां अपनी फ़ाइलें का उपयोग करके कर रहे हैं type cat
और whereis cat
।
gcc
, जो स्वचालित रूप से निष्पादित बिट सेट करता है।
./
प्रोग्राम निष्पादित करने से पहले आपको टाइप करने की आवश्यकता क्यों है ?टर्मिनल में, जब भी आप किसी एप्लिकेशन का नाम लिखते हैं, तो कहते हैं gedit
, टर्मिनल कुछ (पूर्व-निर्धारित) निर्देशिकाओं में दिखेगा, जिसमें एप्लिकेशन (एप्लिकेशनों के बायनेरिज़) होते हैं। इन निर्देशिकाओं के नाम एक चर में निहित हैं PATH
। आप देख सकते हैं कि निष्पादन के द्वारा इस चर में क्या है echo $PATH
। उन निर्देशिकाओं को अलग करके देखें :
? उन निर्देशिकाओं कि टर्मिनल, खोज करता है, तो आप सिर्फ टाइप जाना होगा रहे हैं gedit
, nautilus
या a.out
। जैसा कि आप देख सकते हैं, आपके a.out
कार्यक्रम का मार्ग नहीं है। जब आप ऐसा करते हैं ./a.out
, तो आप टर्मिनल को "वर्तमान निर्देशिका में देखो, और चलाओ a.out
, और देखो मत जाओ " में बता रहे हैं PATH
।
यदि आप ./
हर बार टाइप नहीं करना चाहते हैं , तो आपको a.out
निर्देशिका में जोड़ना होगा $PATH
। निम्नलिखित निर्देशों में, मैं मानूंगा कि रास्ता a.out
है /path/to/programs/
, लेकिन आपको इसे अपने वास्तविक पथ में बदलना चाहिए।
बस फ़ाइल के अंत में निम्नलिखित पंक्ति जोड़ें ~/.pam_environment
:
PATH DEFAULT=${PATH}:/path/to/programs
स्रोत: लगातार पर्यावरण चर
लॉग आउट करें और वापस लॉग इन करें। अब आप किसी भी निर्देशिका से a.out
बिना चला सकेंगे ./
।
यदि आपके पास अन्य निर्देशिकाओं में अन्य कार्यक्रम हैं, तो आप उन्हें उपरोक्त पंक्ति में जोड़ सकते हैं। हालांकि, मैं उदाहरण के लिए "myPrograms" नामक एक निर्देशिका की सलाह दूंगा, और इसके तहत अपने सभी कार्यक्रम डालूंगा।
नोट:
userName
अपने वास्तविक Ubuntu उपयोगकर्ता नाम में परिवर्तन ।
क्या होगा यदि आपके पास अन्य कार्यक्रम हैं जिन्हें आप चलाना चाहते हैं? और वे सभी विभिन्न फ़ोल्डरों में हैं? खैर, एक "अधिक संगठित" समाधान एक फ़ोल्डर बनाने के लिए होगा जिसे bin
आपके होम डायरेक्टरी के तहत कहा जाता है , और उस फ़ोल्डर के तहत प्रतीकात्मक लिंक (शॉर्टकट) जोड़ें। ऐसे:
mkdir /home/userName/bin
bin
आपके होम डायरेक्टरी के तहत फोल्डर बनाएगा ।ln -s /path/to/programs/a.out /home/userName/bin
a.out
प्रोग्राम का "प्रतीकात्मक लिंक" (मूल रूप से, एक शॉर्टकट) बनाएगा bin
।लॉग आउट करें और वापस लॉग इन करें। अब आप किसी भी निर्देशिका से a.out
बिना चला सकेंगे ./
।
अब, जब भी आपका कहीं और कोई कार्यक्रम हो, तो b.in
अपने डेस्कटॉप पर प्रोग्राम को कहें , आपको बस इतना करना है: ln -s /home/userName/Desktop/b.in /home/userName/bin
और फिर आप इसे भी बिना चला सकेंगे ./
।
नोट: @ जो की टिप्पणी के लिए धन्यवाद , जब आप बैकअप करते हैं, तो प्रतीकात्मक लिंक को विशेष रूप से संभालना पड़ता है। डिफ़ॉल्ट रूप से,
rsync
उन्हें बिल्कुल भी संसाधित नहीं करता है, इसलिए जब आप पुनर्स्थापित करते हैं, तो वे वहां नहीं होते हैं।
के रूप में जॉर्ज को अपने जवाब में बताया, यह आप ध्यान दें कि आपके मदद करता है कि क्रियान्वित वर्तमान कार्यशील निर्देशिका में एक फ़ाइल ( pwd
)।
मुझे याद है कि यह प्रश्न बहुत समय पहले मेरे वरिष्ठ से पूछा गया था, उन्होंने कहा कि मुझे .
अपने रास्ते से जुड़ना चाहिए ताकि जब मैं ऐसा करूं तो a.out
वह वर्तमान निर्देशिका में दिखे और उस पर अमल करे। इस मामले में मुझे नहीं करना है ./a.out
।
लेकिन, व्यक्तिगत रूप से, मैं इसके खिलाफ सिफारिश करूंगा। यह मेरे साथ कभी नहीं हुआ, लेकिन यदि आप एक विदेशी नेटवर्क निर्देशिका या कुछ और, और एक दुर्भावनापूर्ण निष्पादन योग्य फ़ाइल पर ls
मौजूद हैं, तो .
आपके रास्ते में होना एक बहुत बुरा विचार है। ऐसा नहीं है कि आप इस समस्या में भाग लेंगे, बस कह रहे हैं।
.
लिए सहमत नहीं हूँ $PATH
। बहुत खतरनाक विचार है।
अन्य उत्तरों के अलावा, यहां से वह आवश्यक हिस्सा man bash
बताया गया है जो अच्छी तरह से समझाता है:
COMMAND EXECUTION एक आदेश के बाद शब्दों में विभाजित किया गया है, अगर यह एक सरल में परिणाम है कमांड और तर्कों की एक वैकल्पिक सूची, निम्नलिखित क्रियाएं हैं लिया। यदि कमांड नाम में कोई स्लैश नहीं है, तो शेल पता लगाने का प्रयास करता है यह। यदि उस नाम से शेल फ़ंक्शन मौजूद है, तो वह फ़ंक्शन है FUNCTIONS में ऊपर वर्णित है। यदि नाम मेल नहीं खाता है फ़ंक्शन, शेल शेल बिल्डरों की सूची में इसके लिए खोज करता है। अगर एक मैच पाया जाता है, कि बिल्टइन मंगवाया गया है। यदि नाम न तो शेल फ़ंक्शन है और न ही एक बिलिन, और न में है स्लैश, बैश एक निर्देशिका शंकु के लिए पथ के प्रत्येक तत्व को खोजता है उस नाम से एक निष्पादन योग्य फ़ाइल बनाना।
जब आप एक प्रोग्राम चलाते हैं, जो आपके लिए विशिष्ट है, जैसे आपका अपना। यह कार्यक्रम आपकी वर्तमान निर्देशिका में मौजूद होना चाहिए। A './' का कोई मतलब नहीं है जब आप एक मानक कमांड चलाते हैं जो $ PATH में कहीं है। एक कमांड "जो कमांड-टू-रन" आपको बताता है कि $ PATH में कमांड-टू-रन कहां है।
$ gcc hello.c -o /path/to/someplace/hello
कुछ स्थान पर एक निष्पादन योग्य उत्पादन करेगा। यदि वह स्थान आपके पथ पर है, तो आप फ़ाइल चला पाएंगे। आप इसे स्क्रिप्ट कर सकते हैं यदि आप कार्रवाई के लिए एक लेबल बनाना पसंद करते हैं "इस स्रोत कोड को gcc का उपयोग करके संकलित करें और अपने स्थान पर कुछ स्थान पर एक निष्पादन योग्य रखें"
मैं आपको एक नई निर्देशिका बनाने का सुझाव दूंगा जिसे "टेस्टबिन" या उस तरह का कुछ कहा जाता है और इसे आपके मौजूदा पथ निर्देशिकाओं को साफ रखने के लिए अपने पथ पर रखा जाता है।
./
एक रास्ते के लिए अनावश्यक खोज को समाप्त करता है। ./
केवल वर्तमान निर्देशिका में खोज करने के लिए बल। अगर हम नहीं देते ./
तो यह विभिन्न पथ सिस्टम की तरह में सेट खोज करेंगे /usr/bin
, /usr/sbin/
आदि
"./" का अर्थ है कि आप वर्तमान निर्देशिका में एक फ़ाइल निष्पादित करना चाहते हैं, उदाहरण के लिए पूरे रास्ते को टाइप करने के लिए एक शॉर्टकट:
[root@server ~]#/path/to/file/file.pl
के रूप में ही है:
[root@server file]#./file.pl
पिछले उदाहरण में आप डायरेक्टरी और उसके सुपर-डायरेक्टरी से फाइल लोकेशन पर गए थे और फाइल को चालू डायरेक्टरी में चलाने के लिए "./" का उपयोग किया था।
इससे पहले कि यह " [रूट @ सर्वर ~] # / पथ / से / फ़ाइल / file.pl " भी फ़ाइल को निष्पादित करेगा यदि आप फ़ाइल स्थान पर अपना रास्ता "सीडी" के लिए आलसी करते हैं।
यह बहुत सरल है और इसके कई उपयोग हैं।
/usr/bin
। उदाहरण के लिए, Python 2.7, Python 2.6 स्थापित है लेकिन / usr / bin / python -> python2.7 / usr / local / bin / python -> python2.6यदि आप पथ में हैं /usr/local/bin
और पायथन को निष्पादित करते हैं तो यह हमेशा पायथन 2.7 को निष्पादित करेगा। निर्दिष्ट .
करने से वर्तमान फ़ोल्डर निष्पादन योग्य हो जाएगा।
.
- हमेशा वर्तमान निर्देशिका से निष्पादन का प्रतिनिधित्व करता है। और ..
हमेशा पिछली निर्देशिका से निष्पादित होता है।