पर्ल - पैकेज और मॉड्यूल
पैकेज क्या हैं?
packageकथन वर्तमान नामकरण संदर्भ को एक निर्दिष्ट नामस्थान (प्रतीक तालिका) पर स्विच करता है। इस प्रकार -
एक पैकेज कोड का एक संग्रह है जो अपने स्वयं के नामस्थान में रहता है।
एक नेमस्पेस अद्वितीय चर नामों का एक संग्रह है (जिसे प्रतीक तालिका भी कहा जाता है)।
नाम स्थान संकुल के बीच चर नाम टकराव को रोकते हैं।
पैकेज मॉड्यूल के निर्माण को सक्षम करते हैं, जो जब उपयोग किया जाता है, तो मॉड्यूल के स्वयं के नामस्थान के बाहर चर और फ़ंक्शन को क्लोब नहीं करेंगे।
पैकेज तब तक प्रभावी रहता है जब तक या तो एक और पैकेज स्टेटमेंट लागू नहीं होता है, या वर्तमान ब्लॉक या फ़ाइल के अंत तक।
आप स्पष्ट रूप से एक पैकेज के भीतर चर का उल्लेख कर सकते हैं :: पैकेज योग्यता।
निम्नलिखित एक फ़ाइल में मुख्य और फू संकुल वाले एक उदाहरण है। यहां पैकेज के नाम को प्रिंट करने के लिए विशेष चर __PACKAGE__ का उपयोग किया गया है।
#!/usr/bin/perl
# This is main package
$i = 1;
print "Package name : " , __PACKAGE__ , " $i\n";
package Foo;
# This is Foo package
$i = 10;
print "Package name : " , __PACKAGE__ , " $i\n";
package main;
# This is again main package
$i = 100;
print "Package name : " , __PACKAGE__ , " $i\n";
print "Package name : " , __PACKAGE__ , " $Foo::i\n";
1;
जब उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Package name : main 1
Package name : Foo 10
Package name : main 100
Package name : main 10
BEGIN और END ब्लॉक
आप BEGIN और END नाम के किसी भी कोड ब्लॉक को परिभाषित कर सकते हैं, जो क्रमशः निर्माता और विध्वंसक के रूप में कार्य करते हैं।
BEGIN { ... }
END { ... }
BEGIN { ... }
END { ... }
हर एक BEGIN ब्लॉक को पर्ल स्क्रिप्ट लोड होने और संकलित किए जाने के बाद निष्पादित किया जाता है, लेकिन किसी भी अन्य स्टेटमेंट को निष्पादित करने से पहले।
पर्ल इंटरप्रेटर के बाहर निकलने से ठीक पहले प्रत्येक END ब्लॉक को निष्पादित किया जाता है।
पर्ल मॉड्यूल बनाते समय BEGIN और END ब्लॉक विशेष रूप से उपयोगी होते हैं।
निम्नलिखित उदाहरण इसका उपयोग दर्शाता है -
#!/usr/bin/perl
package Foo;
print "Begin and Block Demo\n";
BEGIN {
print "This is BEGIN Block\n"
}
END {
print "This is END Block\n"
}
1;
जब उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
This is BEGIN Block
Begin and Block Demo
This is END Block
पर्ल मॉड्यूल क्या हैं?
एक पर्ल मॉड्यूल लाइब्रेरी फ़ाइल में परिभाषित एक पुन: प्रयोज्य पैकेज है, जिसका नाम एएमपी के साथ पैकेज के नाम के समान ही है।
एक पर्ल मॉड्यूल फ़ाइल कहा जाता है Foo.pm इस तरह के बयान हो सकते हैं।
#!/usr/bin/perl
package Foo;
sub bar {
print "Hello $_[0]\n"
}
sub blat {
print "World $_[0]\n"
}
1;
पर्ल मॉड्यूल के बारे में कुछ महत्वपूर्ण बिंदु
कार्य करता है require तथा use एक मॉड्यूल लोड करेगा।
दोनों खोज रास्तों की सूची का उपयोग करते हैं @INC मॉड्यूल खोजने के लिए।
दोनों कार्य require तथा use बुलाएं eval फ़ंक्शन कोड को संसाधित करने के लिए।
1; नीचे TRUE का मूल्यांकन करने के लिए eval का कारण बनता है (और इस प्रकार विफल नहीं)।
आवश्यकता समारोह
मॉड्यूल को कॉल करके लोड किया जा सकता है require कार्य निम्नानुसार है -
#!/usr/bin/perl
require Foo;
Foo::bar( "a" );
Foo::blat( "b" );
आपने देखा होगा कि उन्हें कॉल करने के लिए सबरूटिन नाम पूरी तरह से योग्य होने चाहिए। यह अच्छा होगा कि सबरूटिन को सक्षम करेंbar तथा blat हमारे अपने नामस्थान में आयात किया जाए ताकि हमें फू :: क्वालीफायर का उपयोग न करना पड़े।
उपयोग समारोह
मॉड्यूल को कॉल करके लोड किया जा सकता है use समारोह।
#!/usr/bin/perl
use Foo;
bar( "a" );
blat( "b" );
ध्यान दें कि हमें पैकेज के फ़ंक्शन नामों को पूरी तरह से योग्य नहीं बनाना है। use फ़ंक्शन किसी मॉड्यूल के अंदर कुछ जोड़े गए कथनों को दिए गए मॉड्यूल से प्रतीकों की एक सूची निर्यात करेगा।
require Exporter;
@ISA = qw(Exporter);
फिर, नाम चर सूची को भरकर प्रतीकों (स्केलर्स, सूचियों, हैश, सबरूटीन्स, आदि) की एक सूची प्रदान करें @EXPORT: उदाहरण के लिए -
package Module;
require Exporter;
@ISA = qw(Exporter);
@EXPORT = qw(bar blat);
sub bar { print "Hello $_[0]\n" }
sub blat { print "World $_[0]\n" }
sub splat { print "Not $_[0]\n" } # Not exported!
1;
पर्ल मॉड्यूल ट्री बनाएँ
जब आप अपने पर्ल मॉड्यूल को तैयार करने के लिए तैयार होते हैं, तो एक पर्ल मॉड्यूल ट्री बनाने का मानक तरीका होता है। यह प्रयोग किया जाता हैh2xsउपयोगिता। यह उपयोगिता पर्ल के साथ आती है। यहाँ h2xs का उपयोग करने के लिए वाक्यविन्यास है -
$h2xs -AX -n ModuleName
उदाहरण के लिए, यदि आपका मॉड्यूल उपलब्ध है Person.pm फ़ाइल, तो बस निम्नलिखित आदेश जारी करें -
$h2xs -AX -n Person
यह निम्नलिखित परिणाम का उत्पादन करेगा -
Writing Person/lib/Person.pm
Writing Person/Makefile.PL
Writing Person/README
Writing Person/t/Person.t
Writing Person/Changes
Writing Person/MANIFEST
यहाँ इन विकल्पों का निरसन है -
-A ऑटोलैडर कोड को छोड़ देता है (मॉड्यूल द्वारा उपयोग किया जाता है जो बड़ी संख्या में अक्सर उपयोग किए जाने वाले सबरूटीन्स को परिभाषित करता है)।
-X XS तत्वों को छोड़ देता है (eXternal सबरूटीन, जहां eXternal का अर्थ है बाह्य से पर्ल, यानी C)।
-n मॉड्यूल का नाम निर्दिष्ट करता है।
तो ऊपर कमांड व्यक्ति निर्देशिका के अंदर निम्न संरचना बनाता है। वास्तविक परिणाम ऊपर दिखाया गया है।
- Changes
- Makefile.PL
- MANIFEST (पैकेज में सभी फ़ाइलों की सूची है)
- README
- टी / (परीक्षण फ़ाइलें)
- lib / (वास्तविक स्रोत कोड यहाँ जाता है
तो आखिरकार, आप tarएक फ़ाइल Person.tar.gz में इस निर्देशिका संरचना और आप इसे जहाज कर सकते हैं। आपको उचित निर्देशों के साथ README फाइल को अपडेट करना होगा। आप टी निर्देशिका में कुछ परीक्षण उदाहरण फ़ाइलें भी प्रदान कर सकते हैं।
पर्ल मॉड्यूल स्थापित करना
प्रपत्र tar.gz फ़ाइल में एक पर्ल मॉड्यूल डाउनलोड करें। किसी भी पर्ल मॉड्यूल को स्थापित करने के लिए निम्न अनुक्रम का उपयोग करेंPerson.pm जो के रूप में डाउनलोड किया गया है Person.tar.gz फ़ाइल।
tar xvfz Person.tar.gz
cd Person
perl Makefile.PL
make
make install
पर्ल इंटरप्रेटर में निर्देशिकाओं की एक सूची है जिसमें यह मॉड्यूल (वैश्विक सरणी @INC) की खोज करता है।