पर्ल - पैकेज और मॉड्यूल

पैकेज क्या हैं?

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) की खोज करता है।