स्काला - त्वरित गाइड

स्केल, स्केलेबल लैंग्वेज के लिए छोटा, एक हाइब्रिड फंक्शनल प्रोग्रामिंग लैंग्वेज है। इसे मार्टिन ओडस्की ने बनाया था। स्काला आसानी से ऑब्जेक्ट-ओरिएंटेड और कार्यात्मक भाषाओं की सुविधाओं को एकीकृत करता है। Scala को Java Virtual Machine पर चलाने के लिए संकलित किया गया है। कई मौजूदा कंपनियां, जो व्यावसायिक महत्वपूर्ण अनुप्रयोगों के लिए जावा पर निर्भर हैं, अपने विकास की उत्पादकता, अनुप्रयोगों को बढ़ाने और समग्र विश्वसनीयता को बढ़ावा देने के लिए स्काला की ओर रुख कर रही हैं।

यहां हमने कुछ बिंदु प्रस्तुत किए हैं जो स्काला को एप्लिकेशन डेवलपर्स की पहली पसंद बनाते हैं।

स्काला वस्तु-उन्मुख है

स्काला इस मायने में शुद्ध वस्तु-उन्मुख भाषा है कि हर मूल्य एक वस्तु है। वस्तुओं और प्रकारों के व्यवहार को वर्गों और लक्षणों द्वारा वर्णित किया जाता है जिन्हें बाद के अध्यायों में समझाया जाएगा।

वर्गों द्वारा बढ़ाया जाता है subclassing और एक लचीला mixin-based composition कई विरासत के लिए एक स्वच्छ प्रतिस्थापन के रूप में तंत्र।

स्काला क्रियाशील है

स्काला इस अर्थ में भी एक कार्यात्मक भाषा है कि प्रत्येक फ़ंक्शन एक मान है और प्रत्येक मान एक ऑब्जेक्ट है इसलिए अंततः प्रत्येक फ़ंक्शन एक ऑब्जेक्ट है।

स्केल परिभाषित करने के लिए एक हल्का वाक्यविन्यास प्रदान करता है anonymous functions, यह समर्थन करता है higher-order functions, यह कार्य करने की अनुमति देता है nested, और समर्थन करता है currying। इन अवधारणाओं को बाद के अध्यायों में समझाया जाएगा।

स्काला को वैधानिक रूप से टाइप किया गया है

स्केला, कुछ अन्य वैधानिक रूप से टाइप की गई भाषाओं (सी, पास्कल, रस्ट, आदि) के विपरीत, आपको अनावश्यक प्रकार की जानकारी प्रदान करने की उम्मीद नहीं करता है। आपको ज्यादातर मामलों में एक प्रकार निर्दिष्ट करने की आवश्यकता नहीं है, और आपको निश्चित रूप से इसे दोहराना नहीं है।

स्काला जेवीएम पर चलता है

स्काला को जावा बाइट कोड में संकलित किया गया है जिसे जावा वर्चुअल मशीन (JVM) द्वारा निष्पादित किया जाता है। इसका मतलब है कि स्काला और जावा में एक सामान्य रनटाइम प्लेटफॉर्म है। आप जावा से स्काला तक आसानी से जा सकते हैं।

स्काला संकलक आपके स्काला कोड को जावा बाइट कोड में संकलित करता है, जिसे तब 'द्वारा निष्पादित किया जा सकता है।scala'आज्ञा। 'scala'कमांड के समान है java कमांड, इसमें वह आपके संकलित स्काला कोड को निष्पादित करता है।

Scala Java Code को Execute कर सकता है

स्काला आपको जावा एसडीके के सभी वर्गों और अपने स्वयं के कस्टम जावा कक्षाओं, या अपने पसंदीदा जावा ओपन सोर्स परियोजनाओं का उपयोग करने में सक्षम बनाता है।

स्काला समवर्ती और सिंक्रनाइज़ प्रसंस्करण कर सकता है

स्काला आपको सामान्य प्रोग्रामिंग पैटर्न को प्रभावी तरीके से व्यक्त करने की अनुमति देता है। यह लाइनों की संख्या को कम करता है और प्रोग्रामर को टाइप-सुरक्षित तरीके से कोड करने में मदद करता है। यह आपको एक अपरिवर्तनीय तरीके से कोड लिखने की अनुमति देता है, जिससे समवर्ती और समानांतरवाद (सिंक्रोनाइज़) को लागू करना आसान हो जाता है।

जावा बनाम स्काला

Scala में जावा से पूरी तरह से भिन्न सुविधाओं का एक सेट है। इनमें से कुछ हैं -

  • सभी प्रकार की वस्तुएं हैं
  • प्रकार का अनुमान
  • नेस्टेड कार्य
  • कार्य वस्तुएं हैं
  • डोमेन विशिष्ट भाषा (डीएसएल) समर्थन
  • Traits
  • Closures
  • Erlang द्वारा प्रेरित Concurrency समर्थन

स्काला वेब फ्रेमवर्क

Scala का उपयोग हर जगह और महत्वपूर्ण रूप से एंटरप्राइज़ वेब अनुप्रयोगों में किया जा रहा है। आप कुछ सबसे लोकप्रिय स्काला वेब फ्रेमवर्क की जाँच कर सकते हैं -

  • लिफ्ट की रूपरेखा

  • खेल की रूपरेखा

  • गेंदबाज ढांचा

Scala को किसी भी UNIX फ्लेवर्ड या विंडोज बेस्ड सिस्टम पर इंस्टॉल किया जा सकता है। इससे पहले कि आप अपनी मशीन पर स्कैला स्थापित करना शुरू करें, आपके पास जावा 1.8 या अधिक आपके कंप्यूटर पर स्थापित होना चाहिए।

स्केल स्थापित करने के लिए नीचे दिए गए चरणों का पालन करें।

चरण 1: अपने जावा इंस्टॉलेशन को सत्यापित करें

सबसे पहले, आपको अपने सिस्टम पर जावा सॉफ्टवेयर डेवलपमेंट किट (एसडीके) इंस्टॉल करना होगा। इसे सत्यापित करने के लिए, आप जिस प्लेटफ़ॉर्म पर काम कर रहे हैं, उसके आधार पर निम्नलिखित दो कमांड्स में से किसी को निष्पादित करें।

यदि जावा इंस्टॉलेशन ठीक से किया गया है, तो यह आपके जावा इंस्टॉलेशन के वर्तमान संस्करण और विनिर्देश को प्रदर्शित करेगा। निम्न तालिका में एक नमूना आउटपुट दिया गया है।

मंच आदेश नमूना आउटपुट
खिड़कियाँ

कमांड कंसोल खोलें और टाइप करें -

\>java –version

जावा संस्करण "1.8.0_31"

जावा (टीएम) एसई रन टाइम

पर्यावरण (1.8.0_31-b31 का निर्माण)

जावा हॉटस्पॉट (टीएम) 64-बिट सर्वर

VM (बिल्ड 25.31-b07, मिश्रित मोड)

लिनक्स

ओपन कमांड टर्मिनल और प्रकार -

$java –version

जावा संस्करण "1.8.0_31"

ओपन JDK रनटाइम एनवायरनमेंट (rhel-2.8.10.4.el6_4-x86_64)

ओपन JDK 64-बिट सर्वर VM (बिल्ड 25.31-b07, मिश्रित मोड)

हम मानते हैं कि इस ट्यूटोरियल के पाठकों के पास अपने सिस्टम पर जावा एसडीके संस्करण 1.8.0_31 है।

यदि आपके पास जावा एसडीके नहीं है, तो इसका वर्तमान संस्करण डाउनलोड करें http://www.oracle.com/technetwork/java/javase/downloads/index.html और इसे स्थापित करें।

चरण 2: अपना जावा वातावरण सेट करें

वातावरण चर JAVA_HOME को आधार निर्देशिका स्थान पर इंगित करने के लिए सेट करें जहाँ जावा आपकी मशीन पर स्थापित है। उदाहरण के लिए,

अनु क्रमांक मंच और विवरण
1

Windows

JAVA_HOME को C: \ ProgramFiles \ java \ jdk1.7.0_60 पर सेट करें

2

Linux

निर्यात JAVA_HOME = / usr / स्थानीय / जावा-वर्तमान

जावा कंपाइलर स्थान का पूरा पथ सिस्टम पथ में जोड़ें।

अनु क्रमांक मंच और विवरण
1

Windows

स्ट्रिंग "C: \ Program Files \ Java \ jdk1.7.0_60 \ bin" सिस्टम चर पथ के अंत में जोड़ें।

2

Linux

निर्यात पाथ = $ पाथ: $ जाव_होम / बिन /

आदेश निष्पादित करें java -version ऊपर बताए अनुसार कमांड प्रॉम्प्ट से।

चरण 3: स्कैला स्थापित करें

आप Scala से डाउनलोड कर सकते हैं http://www.scala-lang.org/downloads। इस ट्यूटोरियल को लिखने के समय, मैंने 'scala-2.11.5-installer.jar' डाउनलोड किया। सुनिश्चित करें कि आगे बढ़ने के लिए आपके पास विशेषाधिकार है। अब, कमांड प्रॉम्प्ट पर निम्नलिखित कमांड निष्पादित करें -

मंच कमांड और आउटपुट विवरण
खिड़कियाँ

\> जावा-स्केजर -२.११.५-इंस्टॉलर

यह कमांड एक इंस्टॉलेशन विज़ार्ड प्रदर्शित करेगा, जो आपको अपनी विंडोज़ मशीन पर स्केल स्थापित करने के लिए मार्गदर्शन करेगा। स्थापना के दौरान, यह लाइसेंस समझौते के लिए पूछेगा, बस इसे स्वीकार करें और आगे यह एक रास्ता पूछेगा जहां स्काला स्थापित किया जाएगा। मैंने डिफ़ॉल्ट दिए गए पथ "C: \ Program Files \ Scala" का चयन किया , आप अपनी सुविधा के अनुसार उपयुक्त पथ का चयन कर सकते हैं।

लिनक्स

Command -

$ java –jar scala-2.9.0.1- इंस्टॉलर.जर

Output -

Scala 2.9.0.1 की स्थापना में आपका स्वागत है!

मुखपृष्ठ यहां है - http://Scala-lang.org/

जारी रखने के लिए 1 दबाएं, 2 छोड़ें, 3 को फिर से देखें

1 ................................................

[अनपैक करना शुरू कर रहा है]

[प्रोसेसिंग पैकेज: सॉफ्टवेयर पैकेज इंस्टालेशन (1/1)]

[अनपैकिंग समाप्त]

[कंसोल इंस्टॉलेशन किया गया]

स्थापना के दौरान, यह लाइसेंस समझौते के लिए पूछेगा, इसे टाइप 1 स्वीकार करने के लिए और यह एक रास्ता पूछेगा जहां स्काला स्थापित किया जाएगा। मैंने प्रवेश किया / usr / लोकल / शेयर, आप अपनी सुविधा के अनुसार उपयुक्त पथ का चयन कर सकते हैं।

अंत में, एक नया कमांड प्रॉम्प्ट खोलें और टाइप करें Scala -versionऔर Enter दबाएं। आपको निम्नलिखित देखना चाहिए -

मंच आदेश उत्पादन
खिड़कियाँ

\ _ scala -version

स्काला कोड रनर संस्करण 2.11.5 - कॉपीराइट 2002-2013, LAMP / EPFL

लिनक्स

$ scala -version

स्केल कोड रनर संस्करण 2.9.0.1 - कॉपीराइट 2002-2013, LAMP / EPFL

अगर आपको जावा पर अच्छी समझ है, तो आपके लिए स्काला सीखना बहुत आसान हो जाएगा। स्काला और जावा के बीच सबसे बड़ा वाक्यात्मक अंतर यह है कि ';' लाइन अंत चरित्र वैकल्पिक है।

जब हम एक स्काला प्रोग्राम पर विचार करते हैं, तो इसे उन वस्तुओं के संग्रह के रूप में परिभाषित किया जा सकता है जो एक-दूसरे के तरीकों को लागू करने के माध्यम से संवाद करते हैं। आइए अब संक्षेप में देखते हैं कि कक्षा, वस्तु, विधि और उदाहरण चर क्या हैं।

  • Object- वस्तुओं में राज्य और व्यवहार होते हैं। एक वस्तु एक वर्ग का एक उदाहरण है। उदाहरण - एक कुत्ते की अवस्थाएँ हैं - रंग, नाम, नस्ल के साथ-साथ व्यवहार - वैगिंग, भौंकना और खाना।

  • Class - एक वर्ग को एक टेम्पलेट / खाका के रूप में परिभाषित किया जा सकता है जो वर्ग से संबंधित व्यवहार / स्थिति का वर्णन करता है।

  • Methods- एक विधि मूल रूप से एक व्यवहार है। एक क्लास में कई तरीके हो सकते हैं। यह उन तरीकों में है जहां लॉजिक्स लिखा जाता है, डेटा में हेरफेर किया जाता है और सभी कार्यों को निष्पादित किया जाता है।

  • Fields- प्रत्येक ऑब्जेक्ट के उदाहरण चर का एक अनूठा सेट होता है, जिसे फ़ील्ड कहा जाता है। एक ऑब्जेक्ट की स्थिति इन फ़ील्ड्स को दिए गए मानों द्वारा बनाई गई है।

  • Closure - ए closure एक फ़ंक्शन है, जिसका रिटर्न मान इस फ़ंक्शन के बाहर घोषित एक या अधिक चर के मूल्य पर निर्भर करता है।

  • Traits- एक विशेषता विधि और क्षेत्र परिभाषाओं को एनकैप्सुलेट करती है, जिसे बाद में कक्षाओं में मिलाकर पुन: उपयोग किया जा सकता है। समर्थित विधियों के हस्ताक्षर को निर्दिष्ट करके ऑब्जेक्ट प्रकार को परिभाषित करने के लिए लक्षण का उपयोग किया जाता है।

पहला स्काला प्रोग्राम

हम एक स्केला प्रोग्राम को दो मोड में निष्पादित कर सकते हैं: एक है interactive mode और दूसरा है script mode

इंटरएक्टिव मोड

कमांड प्रॉम्प्ट खोलें और स्केला को खोलने के लिए निम्न कमांड का उपयोग करें।

\>scala

यदि आपके सिस्टम में Scala स्थापित है, तो निम्न आउटपुट प्रदर्शित होगा -

Welcome to Scala version 2.9.0.1
Type in expressions to have them evaluated.
Type :help for more information.

स्काला प्रॉम्प्ट के दाईं ओर निम्न पाठ टाइप करें और Enter कुंजी दबाएं -

scala> println("Hello, Scala!");

यह निम्नलिखित परिणाम का उत्पादन करेगा -

Hello, Scala!

स्क्रिप्ट मोड

स्क्रिप्ट मोड में स्केल प्रोग्राम लिखने के लिए निम्न निर्देशों का उपयोग करें। नोटपैड खोलें और इसमें निम्न कोड जोड़ें।

उदाहरण

object HelloWorld {
   /* This is my first java program.  
   * This will print 'Hello World' as the output
   */
   def main(args: Array[String]) {
      println("Hello, world!") // prints Hello World
   }
}

फ़ाइल को इस रूप में सहेजें - HelloWorld.scala

कमांड प्रॉम्प्ट विंडो खोलें और उस डायरेक्टरी पर जाएं जहां प्रोग्राम फाइल सेव है। 'scalac'कमांड का उपयोग स्काला प्रोग्राम को संकलित करने के लिए किया जाता है और यह वर्तमान निर्देशिका में कुछ क्लास फाइलें उत्पन्न करेगा। उनमें से एक को बुलाया जाएगाHelloWorld.class। यह एक बाइटकोड है जो जावा वर्चुअल मशीन (JVM) पर चलेगा 'scala'आज्ञा।

अपने स्काला प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग करें।

\> scalac HelloWorld.scala
\> scala HelloWorld

उत्पादन

Hello, World!

बेसिक सिंटेक्स

स्केल प्रोग्रामिंग में निम्नलिखित मूल वाक्यविन्यास और कोडिंग कन्वेंशन हैं।

  • Case Sensitivity - स्केला केस-संवेदी है, जिसका अर्थ है पहचानकर्ता Hello तथा hello स्काला में अलग अर्थ होगा।

  • Class Names- सभी वर्ग नामों के लिए, पहला पत्र ऊपरी मामले में होना चाहिए। यदि कक्षा के नाम को बनाने के लिए कई शब्दों का उपयोग किया जाता है, तो प्रत्येक आंतरिक शब्द का पहला अक्षर ऊपरी मामले में होना चाहिए।

    Example - वर्ग MyFirstScalaClass।

  • Method Names- सभी विधि नाम लोअर केस अक्षर से शुरू होने चाहिए। यदि विधि के नाम को बनाने के लिए कई शब्दों का उपयोग किया जाता है, तो प्रत्येक आंतरिक शब्द का पहला अक्षर ऊपरी मामले में होना चाहिए।

    Example - myMethodName () को हराया

  • Program File Name- प्रोग्राम फ़ाइल का नाम ऑब्जेक्ट के नाम से बिल्कुल मेल खाना चाहिए। फ़ाइल को सहेजते समय आपको ऑब्जेक्ट नाम का उपयोग करके इसे सहेजना चाहिए (याद रखें कि स्केला केस-संवेदी है) और संलग्न करें '.scala'नाम के अंत तक। (यदि फ़ाइल का नाम और ऑब्जेक्ट का नाम आपके प्रोग्राम से मेल नहीं खाता है तो संकलन नहीं होगा)।

    Example- मान लें 'HelloWorld' ऑब्जेक्ट नाम है। फिर फ़ाइल को 'HelloWorld.scala' के रूप में सहेजा जाना चाहिए।

  • def main(args: Array[String]) - स्केला प्रोग्राम प्रोसेसिंग मुख्य () विधि से शुरू होती है जो प्रत्येक स्कैला प्रोग्राम का अनिवार्य हिस्सा है।

स्काला पहचानकर्ता

सभी स्काला घटकों को नामों की आवश्यकता होती है। वस्तुओं, वर्गों, चर और विधियों के लिए उपयोग किए जाने वाले नामों को पहचानकर्ता कहा जाता है। किसी कीवर्ड का उपयोग पहचानकर्ता के रूप में नहीं किया जा सकता है और पहचानकर्ता केस-संवेदी होते हैं। स्काला चार प्रकार के पहचानकर्ताओं का समर्थन करता है।

अल्फ़ान्यूमेरिक पहचानकर्ता

अल्फ़ान्यूमेरिक पहचानकर्ता एक अक्षर या अंडरस्कोर के साथ शुरू होता है, जिसे आगे के अक्षरों, अंकों या अंडरस्कोर द्वारा अनुसरण किया जा सकता है। '$' वर्ण स्काला में एक आरक्षित कीवर्ड है और इसे पहचानकर्ताओं में उपयोग नहीं किया जाना चाहिए।

निम्नलिखित हैं legal alphanumeric identifiers -

age, salary, _value,  __1_value

निम्नलिखित हैं illegal identifiers -

$salary, 123abc, -salary

संचालक पहचानकर्ता

एक ऑपरेटर पहचानकर्ता में एक या अधिक ऑपरेटर वर्ण होते हैं। संचालक वर्ण मुद्रण योग्य ASCII वर्ण हैं जैसे +,: ;,?, ~ या #।

निम्नलिखित कानूनी ऑपरेटर पहचानकर्ता हैं -

+ ++ ::: <?> :>

Scala संकलक आंतरिक रूप से "mangle" ऑपरेटर पहचानकर्ताओं को एम्बेडेड $ वर्णों के साथ कानूनी जावा पहचानकर्ता में बदलने के लिए करेगा। उदाहरण के लिए, पहचानकर्ता: -> को आंतरिक रूप से दर्शाया जाएगा$colon$शून्य से $ अधिक से अधिक।

मिश्रित पहचानकर्ता

एक मिश्रित पहचानकर्ता में एक अल्फ़ान्यूमेरिक पहचानकर्ता होता है, जिसके बाद एक अंडरस्कोर और एक ऑपरेटर पहचानकर्ता होता है।

निम्नलिखित कानूनी मिश्रित पहचानकर्ता हैं -

unary_+,  myvar_=

यहाँ, unary_ + को विधि नाम के रूप में उपयोग किया जाता है, unary + ऑपरेटर को परिभाषित करता है और myvar_ = विधि नाम के रूप में उपयोग एक असाइनमेंट ऑपरेटर (ऑपरेटर ओवरलोडिंग) को परिभाषित करता है।

शाब्दिक पहचानकर्ता

एक शाब्दिक पहचानकर्ता एक मनमाना स्ट्रिंग है जो बैक टिक्स (`।।` `) में संलग्न है।

निम्नलिखित कानूनी शाब्दिक पहचानकर्ता हैं -

`x` `<clinit>` `yield`

स्काला कीवर्ड

निम्नलिखित सूची स्काला में आरक्षित शब्दों को दर्शाती है। ये आरक्षित शब्द निरंतर या परिवर्तनशील या किसी अन्य पहचानकर्ता नाम के रूप में उपयोग नहीं किए जा सकते हैं।

सार मामला पकड़ कक्षा
डीईएफ़ कर अन्य फैली
असत्य अंतिम आखिरकार के लिये
कुछ के लिए अगर अंतर्निहित आयात
आलसी मेल खाते हैं नया शून्य
वस्तु अवहेलना पैकेज निजी
संरक्षित वापसी सील उत्तम
यह फेंकना विशेषता प्रयत्न
सच प्रकार वैल वर
जबकि साथ में प्राप्ति  
- : = =>
<- <: <% >:
# @

स्काला में टिप्पणियाँ

स्काला जावा के समान सिंगल-लाइन और मल्टी-लाइन टिप्पणियों का समर्थन करता है। बहु-पंक्ति टिप्पणियों को नेस्टेड किया जा सकता है, लेकिन ठीक से नेस्टेड होना आवश्यक है। किसी भी टिप्पणी के अंदर उपलब्ध सभी पात्रों को स्काला संकलक द्वारा अनदेखा किया जाता है।

object HelloWorld {
   /* This is my first java program.  
    * This will print 'Hello World' as the output
    * This is an example of multi-line comments.
    */
   def main(args: Array[String]) {
      // Prints Hello World
      // This is also an example of single line comment.
      println("Hello, world!") 
   }
}

खाली लाइनें और व्हॉट्सएप

केवल व्हॉट्सएप युक्त एक लाइन, संभवतः एक टिप्पणी के साथ, एक रिक्त रेखा के रूप में जानी जाती है, और स्काला इसे पूरी तरह से अनदेखा करती है। टोकन को व्हाट्सएप पात्रों और / या टिप्पणियों द्वारा अलग किया जा सकता है।

न्यूलाइन वर्ण

स्काला एक लाइन-ओरिएंटेड भाषा है जहाँ स्टेटमेंट्स को अर्धविराम (;) या न्यूलाइन्स द्वारा समाप्त किया जा सकता है। एक बयान के अंत में एक अर्धविराम आमतौर पर वैकल्पिक होता है। आप चाहें तो एक टाइप कर सकते हैं लेकिन आपको यह बताने की जरूरत नहीं है कि स्टेटमेंट एक ही लाइन पर है। दूसरी ओर, यदि आप किसी एकल पंक्ति पर एक से अधिक कथन लिखते हैं, तो अर्धविराम आवश्यक है। सिंटैक्स के नीचे कई कथनों का उपयोग होता है।

val s = "hello"; println(s)

स्काला पैकेज

एक पैकेज कोड का एक नामित मॉड्यूल है। उदाहरण के लिए, लिफ्ट उपयोगिता पैकेज net.liftweb.util है। पैकेज की घोषणा स्रोत फ़ाइल में पहली गैर-टिप्पणी लाइन निम्नानुसार है -

package com.liftcode.stuff

स्केल पैकेज आयात किए जा सकते हैं ताकि उन्हें वर्तमान संकलन दायरे में संदर्भित किया जा सके। निम्न कथन scala.xml पैकेज की सामग्री को आयात करता है -

import scala.xml._

आप एकल वर्ग और ऑब्जेक्ट आयात कर सकते हैं, उदाहरण के लिए, scala.ashlection.mutable पैकेज से HashMap -

import scala.collection.mutable.HashMap

आप एकल पैकेज से एक से अधिक वर्ग या ऑब्जेक्ट आयात कर सकते हैं, उदाहरण के लिए, Scala.collection.immutable पैकेज से TreeMap और TreeSet -

import scala.collection.immutable.{TreeMap, TreeSet}

गतिशील लागू करें

एक मार्कर विशेषता जो गतिशील आह्वान को सक्षम बनाती है। इस विशेषता के उदाहरण x विधि के इनवॉइस x.meth (args) को मनमाने ढंग से नाम मेथ और तर्क सूचियों के साथ-साथ फील्ड एक्सील के लिए मनमाने ढंग से फील्ड नेमफील्ड के लिए अनुमति देते हैं। यह फीचर स्काला -210 में पेश किया गया है।

यदि कोई कॉल मूल रूप से x द्वारा समर्थित नहीं है (अर्थात यदि प्रकार की जाँच विफल हो जाती है), तो यह निम्नलिखित नियमों के अनुसार लिखा जाता है -

foo.method("blah") ~~> foo.applyDynamic("method")("blah")
foo.method(x = "blah") ~~> foo.applyDynamicNamed("method")(("x", "blah"))
foo.method(x = 1, 2) ~~> foo.applyDynamicNamed("method")(("x", 1), ("", 2))
foo.field ~~> foo.selectDynamic("field")
foo.varia = 10 ~~> foo.updateDynamic("varia")(10)
foo.arr(10) = 13 ~~> foo.selectDynamic("arr").update(10, 13)
foo.arr(10) ~~> foo.applyDynamic("arr")(10)

स्काला में जावा के समान सभी डेटा प्रकार हैं, जिसमें समान मेमोरी फ़ुटप्रिंट और परिशुद्धता है। स्केल में उपलब्ध सभी डेटा प्रकारों के बारे में विवरण देने वाली तालिका निम्नलिखित है -

अनु क्रमांक डेटा प्रकार और विवरण
1

Byte

8 बिट हस्ताक्षरित मूल्य। -128 से लेकर 127 तक है

2

Short

16 बिट हस्ताक्षरित मूल्य। रेंज -32768 से 32767 तक

3

Int

32 बिट हस्ताक्षरित मूल्य। रेंज -2147483648 से 2147483647

4

Long

64 बिट हस्ताक्षरित मूल्य। -9223372036854775808 से 9223372036854775807

5

Float

32 बिट IEEE 754 एकल-सटीक फ्लोट

6

Double

64 बिट IEEE 754 डबल-सटीक फ्लोट

7

Char

16 बिट अहस्ताक्षरित यूनिकोड चरित्र। U + 0000 से लेकर U + FFFF तक की रेंज

8

String

चर का एक क्रम

9

Boolean

या तो शाब्दिक सत्य या शाब्दिक असत्य

10

Unit

कोई मूल्य नहीं के अनुरूप

1 1

Null

अशक्त या खाली संदर्भ

12

Nothing

हर दूसरे प्रकार का उपप्रकार; कोई मान शामिल नहीं है

13

Any

किसी भी प्रकार का सुपरटाइप; किसी भी वस्तु प्रकार का है कोई

14

AnyRef

किसी भी संदर्भ प्रकार का सुपरस्क्रिप्ट

ऊपर सूचीबद्ध सभी डेटा प्रकार ऑब्जेक्ट हैं। जावा में कोई आदिम प्रकार नहीं हैं। इसका मतलब है कि आप इंट, लॉन्ग आदि तरीकों को कॉल कर सकते हैं।

स्काला बेसिक लिटरल

शाला द्वारा शाब्दिक के लिए उपयोग किए जाने वाले नियम सरल और सहज हैं। यह खंड सभी मूल स्काला साहित्य की व्याख्या करता है।

एकात्म साहित्य

पूर्णांक के अक्षर आमतौर पर L या l प्रत्यय के बाद Int, या Type के प्रकार के होते हैं। यहाँ कुछ पूर्णांक शाब्दिक हैं -

0
035
21 
0xFFFFFFFF 
0777L

फ्लोटिंग पॉइंट लिटरल

फ़्लोटिंग पॉइंट शाब्दिक फ़्लोट प्रकार के होते हैं, जब फ़्लोटिंग पॉइंट प्रकार प्रत्यय एफ या एफ द्वारा, और टाइप डबल के होते हैं अन्यथा। यहाँ कुछ अस्थायी बिंदु शाब्दिक हैं -

0.0 
1e30f 
3.14159f 
1.0e100
.1

बूलियन लिटरल

बूलियन शाब्दिक true तथा false बुलियन के सदस्य हैं।

प्रतीक साहित्य

एक प्रतीक शाब्दिक 'एक्स एक्सप्रेशन के लिए एक शॉर्टहैंड है scala.Symbol("x")। प्रतीक एक केस क्लास है, जिसे निम्नानुसार परिभाषित किया गया है।

package scala
final case class Symbol private (name: String) {
   override def toString: String = "'" + name
}

चरित्र साहित्य

एक चरित्र शाब्दिक उद्धरणों में संलग्न एक एकल चरित्र है। चरित्र या तो एक मुद्रण योग्य यूनिकोड वर्ण है या एक एस्केप अनुक्रम द्वारा वर्णित है। यहाँ कुछ चरित्र शाब्दिक हैं -

'a' 
'\u0041'
'\n'
'\t'

स्ट्रिंग लिटरल

एक स्ट्रिंग शाब्दिक दोहरे उद्धरण में वर्णों का एक क्रम है। वर्ण या तो मुद्रण योग्य यूनिकोड वर्ण हैं या एस्केप अनुक्रम द्वारा वर्णित हैं। यहाँ कुछ स्ट्रिंग शाब्दिक हैं -

"Hello,\nWorld!"
"This string contains a \" character."

मल्टी-लाइन स्ट्रिंग्स

एक मल्टी-लाइन स्ट्रिंग शाब्दिक ट्रिपल उद्धरण "" "..." "" में संलग्न वर्णों का एक क्रम है। वर्णों का क्रम मनमाना है, सिवाय इसके कि इसमें तीन या अधिक लगातार बोली वर्ण केवल बहुत अंत में हो सकते हैं।

वर्ण अनिवार्य रूप से प्रिंट करने योग्य नहीं होना चाहिए; newlines या अन्य नियंत्रण वर्ण भी अनुमत हैं। यहाँ एक बहु-पंक्ति स्ट्रिंग शाब्दिक है -

"""the present string
spans three
lines."""

अशक्त मान

अशक्त मान प्रकार का होता है scala.Nullऔर इस प्रकार हर संदर्भ प्रकार के साथ संगत है। यह एक संदर्भ मूल्य को दर्शाता है जो एक विशेष "अशक्त" ऑब्जेक्ट को संदर्भित करता है।

बच अनुक्रम

निम्नलिखित भागने के अनुक्रम चरित्र और स्ट्रिंग शाब्दिक में पहचाने जाते हैं।

बच अनुक्रम यूनिकोड विवरण
\ b \ u0008 बैकस्पेस बी.एस.
\ t \ u0009 क्षैतिज टैब HT
\ n \ u000c एफएफ को फॉर्मफीड करें
\ च \ u000c एफएफ को फॉर्मफीड करें
\ r \ u000d गाड़ी वापसी सी.आर.
\ " \ u0022 दोहरे उद्धरण "
\ ' \ u0027 एकल बोली ।
\\ \ u005c बैकस्लैश \ _

0 और 255 के बीच यूनिकोड के साथ एक चरित्र को एक अष्टक एस्केप द्वारा भी दर्शाया जा सकता है, अर्थात, एक बैकस्लैश '\', जिसके बाद तीन ऑक्टल वर्णों का क्रम होता है। निम्नलिखित कुछ अनुक्रम अनुक्रम दिखाने के लिए उदाहरण है -

उदाहरण

object Test {
   def main(args: Array[String]) {
      println("Hello\tWorld\n\n" );
   }
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

उत्पादन

Hello   World

वेरिएबल्स मूल्यों को संग्रहीत करने के लिए आरक्षित मेमोरी स्थानों के अलावा कुछ भी नहीं हैं। इसका मतलब यह है कि जब आप एक चर बनाते हैं, तो आप स्मृति में कुछ स्थान आरक्षित करते हैं।

एक चर के डेटा प्रकार के आधार पर, संकलक मेमोरी आवंटित करता है और यह तय करता है कि आरक्षित मेमोरी में क्या संग्रहीत किया जा सकता है। इसलिए, भिन्न प्रकार के डेटा को चर के लिए असाइन करके, आप इन चर में पूर्णांक, दशमलव या वर्ण संग्रहीत कर सकते हैं।

परिवर्तनीय घोषणा

वैरिएबल घोषित करने के लिए स्काला का एक अलग वाक्यविन्यास है। उन्हें मूल्य के रूप में परिभाषित किया जा सकता है, अर्थात, स्थिर या एक चर। यहां, कीवर्ड संस्करण का उपयोग करके myVar घोषित किया गया है। यह एक वैरिएबल है जो मूल्य को बदल सकता है और इसे कहा जाता हैmutable variable। निम्नलिखित चर का उपयोग करके परिभाषित करने के लिए सिंटैक्स हैvar कीवर्ड -

वाक्य - विन्यास

var myVar : String = "Foo"

यहां, कीवर्ड वैल का उपयोग करके myVal घोषित किया गया है। इसका अर्थ है कि यह एक परिवर्तनशील चर है जिसे बदला नहीं जा सकता है और इसे कहा जाता हैimmutable variable। वैल कीवर्ड का उपयोग करते हुए एक चर को परिभाषित करने के लिए सिंटैक्स निम्नलिखित है -

वाक्य - विन्यास

val myVal : String = "Foo"

चर डेटा प्रकार

वैरिएबल का प्रकार वैरिएबल नाम के बाद और बराबर साइन से पहले निर्दिष्ट किया जाता है। आप अपने डेटा प्रकार का उल्लेख करके किसी भी प्रकार के स्काला वेरिएबल को परिभाषित कर सकते हैं -

वाक्य - विन्यास

val or val VariableName : DataType = [Initial Value]

यदि आप किसी वैरिएबल को कोई प्रारंभिक मान नहीं देते हैं, तो यह निम्नानुसार मान्य है -

वाक्य - विन्यास

var myVar :Int;
val myVal :String;

परिवर्तनीय प्रकार का आविष्कार

जब आप किसी वैरिएबल को एक प्रारंभिक मान देते हैं, तो स्केल कंपाइलर इसके द्वारा दिए गए मान के आधार पर वैरिएबल के प्रकार का पता लगा सकता है। इसे वेरिएबल टाइप इंट्रेंस कहा जाता है। इसलिए, आप इन परिवर्तनीय घोषणाओं को इस तरह लिख सकते हैं -

वाक्य - विन्यास

var myVar = 10;
val myVal = "Hello, Scala!";

यहां, डिफ़ॉल्ट रूप से, myVar Int प्रकार होगा और MyVal स्ट्रिंग प्रकार चर बन जाएगा।

एकाधिक कार्य

स्काला कई असाइनमेंट का समर्थन करता है। यदि कोई कोड ब्लॉक या विधि एक टपल लौटाता है (Tuple- विभिन्न प्रकार की वस्तुओं का संग्रह), टपल को एक वैर चर को सौंपा जा सकता है। [Note - हम बाद के अध्यायों में ट्यूपल्स का अध्ययन करेंगे।]

वाक्य - विन्यास

val (myVar1: Int, myVar2: String) = Pair(40, "Foo")

और प्रकार का अनुमान सही हो जाता है -

वाक्य - विन्यास

val (myVar1, myVar2) = Pair(40, "Foo")

उदाहरण कार्यक्रम

निम्नलिखित एक उदाहरण कार्यक्रम है जो स्काला में चर घोषणा की प्रक्रिया को समझाता है। यह कार्यक्रम चार चरों की घोषणा करता है - दो चरों को प्रकार की घोषणा के साथ परिभाषित किया जाता है और शेष दो प्रकार बिना घोषणा के होते हैं।

उदाहरण

object Demo {
   def main(args: Array[String]) {
      var myVar :Int = 10;
      val myVal :String = "Hello Scala with datatype declaration.";
      var myVar1 = 20;
      val myVal1 = "Hello Scala new without datatype declaration.";
      
      println(myVar); println(myVal); println(myVar1); 
      println(myVal1);
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

10
Hello Scala with datatype declaration.
20
Hello Scala without datatype declaration.

चर स्कोप

स्काला में चर के तीन अलग-अलग स्कोप हो सकते हैं जो उस जगह पर निर्भर करते हैं जहां उनका उपयोग किया जा रहा है। वे फ़ील्ड पैरामीटर विधि के रूप में और स्थानीय चर के रूप में मौजूद हो सकते हैं। नीचे प्रत्येक प्रकार के दायरे के बारे में विवरण दिया गया है।

खेत

फ़ील्ड वैरिएबल हैं जो किसी ऑब्जेक्ट से संबंधित हैं। ऑब्जेक्ट में प्रत्येक विधि के अंदर से फ़ील्ड सुलभ हैं। फ़ील्ड के साथ घोषित किए गए एक्सेस मॉडिफायर के आधार पर ऑब्जेक्ट के बाहर फ़ील्ड्स भी सुलभ हो सकते हैं। ऑब्जेक्ट फ़ील्ड परस्पर और अपरिवर्तनीय दोनों प्रकार के हो सकते हैं और दोनों का उपयोग करके परिभाषित किया जा सकता हैvar या val

विधि पैरामीटर्स

विधि पैरामीटर चर हैं, जिनका उपयोग किसी विधि के अंदर मान पास करने के लिए किया जाता है, जब विधि को बुलाया जाता है। विधि पैरामीटर केवल विधि के अंदर से ही सुलभ हैं, लेकिन पास की गई वस्तुएं बाहर से सुलभ हो सकती हैं, यदि आपके पास विधि के बाहर से वस्तु का संदर्भ है। विधि पैरामीटर हमेशा अपरिवर्तनीय होते हैं जिन्हें द्वारा परिभाषित किया जाता हैval कीवर्ड।

स्थानीय चर

स्थानीय चर एक विधि के अंदर घोषित चर हैं। स्थानीय चर केवल विधि के अंदर से सुलभ होते हैं, लेकिन आपके द्वारा बनाई गई वस्तुएं विधि से बच सकती हैं यदि आप उन्हें विधि से वापस करते हैं। स्थानीय चर दोनों परिवर्तनशील और अपरिवर्तनीय प्रकार हो सकते हैं और दोनों का उपयोग करके परिभाषित किया जा सकता हैvar या val

यह अध्याय आपको स्कैला प्रोग्रामिंग में कक्षाओं और वस्तुओं का उपयोग करने के तरीके के माध्यम से लेता है। एक वर्ग वस्तुओं के लिए एक खाका है। एक बार जब आप एक क्लास को परिभाषित करते हैं, तो आप कीवर्ड के साथ क्लास ब्लूप्रिंट से ऑब्जेक्ट बना सकते हैंnew। ऑब्जेक्ट के माध्यम से आप परिभाषित वर्ग की सभी कार्यक्षमता का उपयोग कर सकते हैं।

निम्न आरेख कक्षा के छात्र का उदाहरण लेकर कक्षा और ऑब्जेक्ट को प्रदर्शित करता है, जिसमें सदस्य चर (नाम और रोल नंबर) और सदस्य विधियाँ (सेटनाम () और सेट रोलो ()) शामिल हैं। अंत में सभी वर्ग के सदस्य हैं। क्लास एक ब्लू प्रिंट है और ऑब्जेक्ट यहां असली हैं। निम्नलिखित आरेख में, छात्र एक वर्ग है और हारिनी, जॉन और मारिया छात्र वर्ग की वस्तुएं हैं, जिनका नाम और रोल-नंबर है।

बेसिक क्लास

स्काला में एक मूल वर्ग को परिभाषित करने के लिए एक सरल वाक्यविन्यास निम्नलिखित है। यह वर्ग दो चर को परिभाषित करता हैx तथा y और एक विधि: move, जो एक मूल्य वापस नहीं करता है। वर्ग चर कहलाते हैं, वर्ग के क्षेत्र और विधियों को वर्ग विधि कहा जाता है।

क्लास का नाम क्लास कंस्ट्रक्टर के रूप में काम करता है जो कई मापदंडों को ले सकता है। उपरोक्त कोड दो कंस्ट्रक्टर तर्क को परिभाषित करता है,xc तथा yc; वे दोनों कक्षा के पूरे शरीर में दिखाई देते हैं।

वाक्य - विन्यास

class Point(xc: Int, yc: Int) {
   var x: Int = xc
   var y: Int = yc

   def move(dx: Int, dy: Int) {
      x = x + dx
      y = y + dy
      println ("Point x location : " + x);
      println ("Point y location : " + y);
   }
}

जैसा कि पहले इस अध्याय में बताया गया है, आप एक कीवर्ड का उपयोग करके ऑब्जेक्ट बना सकते हैं new और फिर आप वर्ग फ़ील्ड और विधियों का उपयोग कर सकते हैं जैसा कि नीचे उदाहरण में दिखाया गया है -

उदाहरण

import java.io._

class Point(val xc: Int, val yc: Int) {
   var x: Int = xc
   var y: Int = yc
   
   def move(dx: Int, dy: Int) {
      x = x + dx
      y = y + dy
      println ("Point x location : " + x);
      println ("Point y location : " + y);
   }
}

object Demo {
   def main(args: Array[String]) {
      val pt = new Point(10, 20);

      // Move to a new location
      pt.move(10, 10);
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

Point x location : 20
Point y location : 30

एक वर्ग का विस्तार

आप एक बेस स्काला क्लास का विस्तार कर सकते हैं और आप उसी तरह से विरासत में मिला हुआ क्लास डिजाइन कर सकते हैं, जैसा कि आप इसे जावा में करते हैं extends कुंजी शब्द), लेकिन दो प्रतिबंध हैं: विधि को ओवरराइड करने की आवश्यकता होती है override कीवर्ड, और केवल primaryकंस्ट्रक्टर बेस कंस्ट्रक्टर को पैरामीटर पास कर सकता है। आइए हम अपने उपरोक्त वर्ग का विस्तार करें और एक और वर्ग विधि जोड़ें।

उदाहरण

आइए हम दो वर्गों का उदाहरण लेते हैं पॉइंट क्लास (ऊपर जैसा उदाहरण) और लोकेशन क्लास एक्सटेंडेड कीवर्ड का उपयोग करके विरासत में मिला वर्ग है। इस तरह के एक 'extends'खंड के दो प्रभाव हैं: यह स्थान वर्ग को सभी गैर-निजी सदस्यों को पॉइंट क्लास से इनहेरिट करता है, और यह टाइप लोकेशन को पॉइंट क्लास के प्रकार का उपप्रकार बनाता है । इसलिए यहां प्वाइंट क्लास कहा जाता हैsuperclassऔर वर्ग स्थान कहा जाता हैsubclass। एक वर्ग का विस्तार और एक मूल वर्ग की सभी विशेषताओं को विरासत में कहा जाता हैinheritance लेकिन स्काला केवल एक वर्ग से विरासत की अनुमति देता है।

Note - पॉइंट क्लास में मेथड्स मूव () मेथड और move() method in Location class चाल की संबंधित परिभाषाओं को ओवरराइड न करें क्योंकि वे अलग-अलग परिभाषाएं हैं (उदाहरण के लिए, पूर्व दो तर्क लेते हैं जबकि बाद वाले तीन तर्क देते हैं)।

विरासत को लागू करने के लिए निम्नलिखित उदाहरण कार्यक्रम का प्रयास करें।

import java.io._

class Point(val xc: Int, val yc: Int) {
   var x: Int = xc
   var y: Int = yc
   
   def move(dx: Int, dy: Int) {
      x = x + dx
      y = y + dy
      println ("Point x location : " + x);
      println ("Point y location : " + y);
   }
}

class Location(override val xc: Int, override val yc: Int,
   val zc :Int) extends Point(xc, yc){
   var z: Int = zc

   def move(dx: Int, dy: Int, dz: Int) {
      x = x + dx
      y = y + dy
      z = z + dz
      println ("Point x location : " + x);
      println ("Point y location : " + y);
      println ("Point z location : " + z);
   }
}

object Demo {
   def main(args: Array[String]) {
      val loc = new Location(10, 20, 15);

      // Move to a new location
      loc.move(10, 10, 5);
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

Point x location : 20
Point y location : 30
Point z location : 20

इंप्लिमेंट क्लासेस

जब क्लास स्कोप में हो तो इंप्लसिट क्लासेस क्लास के प्राइमरी कंस्ट्रक्टर के साथ निहित बातचीत की अनुमति देती हैं। इंप्लसिट क्लास एक वर्ग है जिसे 'निहित' कीवर्ड से चिह्नित किया जाता है। यह फीचर स्कैला 2.10 में पेश किया गया है।

Syntax- निहित वर्गों के लिए निम्नलिखित सिंटैक्स है। यहां निहित वर्ग हमेशा ऑब्जेक्ट स्कोप में होता है, जहां सभी विधि परिभाषाओं की अनुमति होती है क्योंकि निहित वर्ग एक शीर्ष स्तर वर्ग नहीं हो सकता है।

वाक्य - विन्यास

object <object name> {
   implicit class <class name>(<Variable>: Data type) {
      def <method>(): Unit =
   }
}

उदाहरण

आइए हम एक अंतर्निहित वर्ग का उदाहरण लेते हैं जिसका नाम है IntTimesविधि समय के साथ ()। इसका अर्थ है कि समय () में एक लूप लेनदेन होता है जो दिए गए कथन को उस समय की संख्या में निष्पादित करेगा जो हम देते हैं। आइए मान लेते हैं कि दिया गया कथन "4 गुना प्रिंट्लन (" हैलो ") है। इसका मतलब है कि प्रिंटल (" हैलो ") विवरण 4 बार निष्पादित होगा।

निम्नलिखित दिए गए उदाहरण के लिए कार्यक्रम है। इस उदाहरण में दो ऑब्जेक्ट क्लास का उपयोग किया जाता है (रन और डेमो) ताकि हमें उन दो वर्गों को अलग-अलग फाइलों में उनके संबंधित नामों के साथ निम्नानुसार सहेजना पड़े।

Run.scala - Run.scala में निम्न प्रोग्राम को सहेजें।

object Run {
   implicit class IntTimes(x: Int) {
      def times [A](f: =>A): Unit = {
         def loop(current: Int): Unit =
         
         if(current > 0){
            f
            loop(current - 1)
         }
         loop(x)
      }
   }
}

Demo.scala - Demo.scala में निम्न प्रोग्राम को सेव करें।

import Run._

object Demo {
   def main(args: Array[String]) {
      4 times println("hello")
   }
}

इन दो कार्यक्रमों को संकलित करने और निष्पादित करने के लिए निम्नलिखित कमांड का उपयोग किया जाता है।

आदेश

\>scalac Run.scala
\>scalac Demo.scala
\>scala Demo

उत्पादन

Hello
Hello
Hello
Hello

Note -

  • इंप्लसिव क्लासेस को दूसरे क्लास / ऑब्जेक्ट / ट्रेल (टॉप लेवल में नहीं) के अंदर परिभाषित किया जाना चाहिए।

  • निहित वर्ग अपने निर्माता में केवल एक ही गैर-तर्कपूर्ण तर्क ले सकते हैं।

  • निहित वर्ग के समान नाम के साथ किसी भी वर्ग, सदस्य या वस्तु के दायरे में इंप्लिकेट कक्षाएं नहीं हो सकती हैं।

सिंगलटन ऑब्जेक्ट्स

स्काला जावा की तुलना में अधिक ऑब्जेक्ट-ओरिएंटेड है क्योंकि स्काला में, हमारे पास स्थैतिक सदस्य नहीं हो सकते हैं। इसके बजाय, स्काला हैsingleton objects। एक सिंगलटन एक ऐसा वर्ग है जिसमें केवल एक उदाहरण हो सकता है, अर्थात, वस्तु। आप कीवर्ड का उपयोग करके सिंगलटन बनाते हैंobjectक्लास कीवर्ड के बजाय। चूंकि आप एक सिंगलटन ऑब्जेक्ट को इंस्टेंट नहीं कर सकते हैं, आप प्राथमिक कंस्ट्रक्टर को पैरामीटर पास नहीं कर सकते। आपने पहले से ही सभी उदाहरणों को सिंगलटन ऑब्जेक्ट्स का उपयोग करके देखा है, जहां आप स्काला की मुख्य विधि कहते हैं।

निम्नलिखित सिंगलटन को लागू करने के लिए एक ही उदाहरण कार्यक्रम है।

उदाहरण

import java.io._

class Point(val xc: Int, val yc: Int) {
   var x: Int = xc
   var y: Int = yc
   
   def move(dx: Int, dy: Int) {
      x = x + dx
      y = y + dy
   }
}

object Demo {
   def main(args: Array[String]) {
      val point = new Point(10, 20)
      printPoint

      def printPoint{
         println ("Point x location : " + point.x);
         println ("Point y location : " + point.y);
      }
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

Point x location : 10
Point y location : 20

यह अध्याय आपको स्काला एक्सेस मॉडिफायर के माध्यम से ले जाता है। संकुल, वर्गों या वस्तुओं के सदस्यों को निजी और संरक्षित एक्सेस मॉडिफायर के साथ लेबल किया जा सकता है, और यदि हम इन दोनों में से किसी भी कीवर्ड का उपयोग नहीं कर रहे हैं, तो एक्सेस को सार्वजनिक माना जाएगा। ये संशोधक सदस्यों तक कोड के कुछ क्षेत्रों तक पहुंच को प्रतिबंधित करते हैं। एक्सेस मोडिफायर का उपयोग करने के लिए, आप इसके कीवर्ड को पैकेज, वर्ग या ऑब्जेक्ट के सदस्यों की परिभाषा में शामिल करते हैं जैसा कि हम निम्नलिखित अनुभाग में देखेंगे।

निजी सदस्य

एक निजी सदस्य केवल कक्षा या ऑब्जेक्ट के अंदर दिखाई देता है जिसमें सदस्य की परिभाषा होती है।

निजी सदस्य को समझाने के लिए उदाहरण कोड स्निपेट निम्नलिखित है -

उदाहरण

class Outer {
   class Inner {
      private def f() { println("f") }
      
      class InnerMost {
         f() // OK
      }
   }
   (new Inner).f() // Error: f is not accessible
}

स्काला में, एक्सेस (नया इनर)। f () गैरकानूनी है क्योंकि f को भीतर में निजी घोषित किया गया है और पहुँच वर्ग के भीतर से नहीं है। इसके विपरीत, वर्ग इनरमॉस्ट में एफ की पहली पहुंच ठीक है, क्योंकि यह पहुंच कक्षा इनर के शरीर में निहित है। जावा दोनों एक्सेस की अनुमति देगा क्योंकि यह एक बाहरी वर्ग को अपने आंतरिक वर्गों के निजी सदस्यों तक पहुंचने देता है।

रक्षित सदस्य

एक संरक्षित सदस्य केवल उस वर्ग के उपवर्गों से सुलभ होता है जिसमें सदस्य परिभाषित होता है।

संरक्षित सदस्य को समझाने के लिए उदाहरण कोड स्निपेट निम्नलिखित है -

उदाहरण

package p {
   class Super {
      protected def f() { println("f") }
   }
   
   class Sub extends Super {
      f()
   }
   
   class Other {
      (new Super).f() // Error: f is not accessible
   }
}

क्लास सब में एफ की पहुंच ठीक है क्योंकि एफ को 'सुपर' क्लास में संरक्षित घोषित किया गया है और 'सब' क्लास सुपर का एक उपवर्ग है। इसके विपरीत 'अन्य' वर्ग में f की पहुँच की अनुमति नहीं है, क्योंकि वर्ग 'अन्य' वर्ग 'Super' से विरासत में नहीं मिलता है। जावा में, बाद की पहुंच को अभी भी अनुमति दी जाएगी क्योंकि 'अन्य' वर्ग 'उप' वर्ग के समान पैकेज में है।

सार्वजनिक सदस्य

निजी और संरक्षित सदस्यों के विपरीत, सार्वजनिक सदस्यों के लिए सार्वजनिक कीवर्ड निर्दिष्ट करना आवश्यक नहीं है। सार्वजनिक सदस्यों के लिए कोई स्पष्ट संशोधक नहीं है। ऐसे सदस्यों को कहीं से भी पहुँचा जा सकता है।

सार्वजनिक सदस्य को समझाने के लिए उदाहरण कोड स्निपेट निम्नलिखित है -

उदाहरण

class Outer {
   class Inner {
      def f() { println("f") }
      
      class InnerMost {
         f() // OK
      }
   }
   (new Inner).f() // OK because now f() is public
}

संरक्षण का दायरा

स्काला में एक्सेस मॉडिफायर को क्वालिफायर के साथ बढ़ाया जा सकता है। निजी [X] या संरक्षित [X] फॉर्म का एक संशोधक का अर्थ है कि एक्सेस "X" तक निजी या संरक्षित है, जहां X कुछ संलग्न पैकेज, वर्ग या सिंगलटन ऑब्जेक्ट को नामित करता है।

निम्नलिखित उदाहरण पर विचार करें -

उदाहरण

package society {
   package professional {
      class Executive {
         private[professional] var workDetails = null
         private[society] var friends = null
         private[this] var secrets = null

         def help(another : Executive) {
            println(another.workDetails)
            println(another.secrets) //ERROR
         }
      }
   }
}

Note - उपरोक्त उदाहरण से निम्नलिखित बिंदु -

  • वैरिएबल वर्कडेलेट्स संलग्नक पैकेज पेशेवर के भीतर किसी भी वर्ग के लिए सुलभ होंगे।

  • वैराग्य मित्रों को संलग्न समाज के किसी भी वर्ग के लिए सुलभ होगा।

  • चर रहस्य केवल उदाहरण के तरीकों (यह) के भीतर निहित वस्तु पर ही पहुंचेंगे।

एक ऑपरेटर एक प्रतीक है जो संकलक को विशिष्ट गणितीय या तार्किक जोड़तोड़ करने के लिए कहता है। स्काला बिल्ट-इन ऑपरेटरों से समृद्ध है और निम्नलिखित प्रकार के ऑपरेटर प्रदान करता है -

  • अंकगणितीय आपरेटर
  • संबंधपरक संकारक
  • लॉजिकल ऑपरेटर्स
  • बिटवाइज ऑपरेटर्स
  • असाइनमेंट ऑपरेटर्स

यह अध्याय एक-एक करके अंकगणित, संबंधपरक, तार्किक, बिटवाइज़, असाइनमेंट और अन्य ऑपरेटरों की जाँच करेगा।

अंकगणितीय आपरेटर

निम्नलिखित अंकगणित संचालकों को स्काला भाषा द्वारा समर्थित है। उदाहरण के लिए, मान लें कि वेरिएबल A में 10 और वेरिएबल B में 20 हैं, तो -

उदाहरण दिखाएं

ऑपरेटर विवरण उदाहरण
+ दो ऑपरेंड जोड़ता है A + B 30 देगा
- पहले से दूसरे ऑपरेंड को घटाता है A - B देगा -10
* दोनों ऑपरेंड को गुणा करता है A * B 200 देगा
/ डी-न्यूमेरियर द्वारा अंशों को विभाजित करता है B / A 2 देगा
% मापांक संचालक एक संख्या को दूसरे के विभाजन के बाद शेष पाता है ब% ए द 0 दे खेंगे

संबंधपरक संकारक

निम्नलिखित रिलेशनल ऑपरेटर स्काला भाषा द्वारा समर्थित हैं। उदाहरण के लिए मान लें कि वेरिएबल A में 10 और वेरिएबल B में 20 हैं, तो -

उदाहरण दिखाएं

ऑपरेटर विवरण उदाहरण
== जाँच करता है कि दो ऑपरेंड के मान समान हैं या नहीं, यदि हाँ तो स्थिति सच हो जाती है। (ए == बी) सच नहीं है।
! = जाँच करता है कि दो ऑपरेंड के मान समान हैं या नहीं, यदि मान बराबर नहीं हैं तो स्थिति सत्य हो जाती है। (ए! = बी) सच है।
> यह जाँचता है कि क्या बाएं संकार्य का मान दाहिने संचालक के मान से अधिक है, यदि हाँ, तो स्थिति सत्य है। (ए> बी) सच नहीं है।
< यह जाँचता है कि क्या बाएं संकार्य का मान दाहिने संचालक के मान से कम है, यदि हाँ, तो स्थिति सही है। (ए <बी) सच है।
> = जाँच करता है कि क्या बाएं ऑपरेंड का मूल्य सही ऑपरेंड के मूल्य से अधिक या उसके बराबर है, यदि हाँ तो स्थिति सच हो जाती है। (ए> = बी) सच नहीं है।
<= जाँच करता है कि क्या बाएं संकार्य का मान दाहिने संचालक के मान से कम या उसके बराबर है, यदि हाँ तो स्थिति सत्य हो जाती है। (ए <= बी) सच है।

लॉजिकल ऑपरेटर्स

निम्नलिखित तार्किक ऑपरेटरों को स्काला भाषा द्वारा समर्थित किया जाता है। उदाहरण के लिए, मान लें कि A A 1 रखता है और चर B, 0 रखता है -

उदाहरण दिखाएं

ऑपरेटर विवरण उदाहरण
&& इसे लॉजिकल एंड ऑपरेटर कहा जाता है। यदि दोनों ऑपरेंड नॉन जीरो हैं तो कंडीशन सही हो जाती है। (A && B) गलत है।
|| इसे लॉजिकल या ऑपरेटर कहा जाता है। यदि दोनों संचालकों में से कोई भी गैर शून्य है तो स्थिति सत्य हो जाती है। (ए || बी) सच है
! इसे लॉजिकल नॉट ऑपरेटर कहा जाता है। उपयोग अपने ऑपरेंड की तार्किक स्थिति को उलट देता है। यदि कोई शर्त सही है तो लॉजिकल नॉट ऑपरेटर गलत साबित करेगा। ! (A && B) सत्य है।

बिटवाइज ऑपरेटर्स

बिटवाइज ऑपरेटर बिट्स पर काम करता है और बिट ऑपरेशन द्वारा बिट करता है। सत्य सारणी &,; और ^ के लिए निम्नानुसार हैं -

पी क्यू पी क्यू पी | क्यू p ^ q
0 0 0 0 0
0 1 0 1 1
1 1 1 1 0
1 0 0 1 1

मान लें कि ए = 60; और बी = 13; अब द्विआधारी प्रारूप में वे निम्नानुसार होंगे -

A = 0011 1100
B = 0000 1101
-----------------------
A&B = 0000 1100
A|B = 0011 1101
A^B = 0011 0001
~A = 1100 0011

स्काला भाषा द्वारा समर्थित बिटवाइज़ ऑपरेटरों को निम्न तालिका में सूचीबद्ध किया गया है। चर ए मान लें 60 और चर बी 13 रखता है, तो -

उदाहरण दिखाएं

ऑपरेटर विवरण उदाहरण
और बाइनरी और ऑपरेटर परिणाम के लिए थोड़ा सा कॉपी करता है यदि यह दोनों ऑपरेंड में मौजूद है। (A & B) 12 देगा, जो 0000 1100 है
| बाइनरी या ऑपरेटर थोड़ा सा कॉपी करता है अगर यह किसी भी ऑपरेंड में मौजूद है। (ए | बी) 61 देगा, जो 0011 1101 है
^ बाइनरी एक्सओआर ऑपरेटर बिट को कॉपी करता है यदि यह एक ऑपरेंड में सेट होता है लेकिन दोनों नहीं। (ए ^ बी) 49 देगा, जो 0011 0001 है
~ बाइनरी ओन्स कंप्लीट ऑपरेटर, एकात्मक है और इसमें 'फ्लिपिंग' बिट्स का प्रभाव होता है। (~ ए) -61 देगा, जो कि हस्ताक्षरित बाइनरी नंबर के कारण 2 के पूरक रूप में 1100 0011 है।
<< बाइनरी लेफ्ट शिफ्ट ऑपरेटर। बाएं ऑपरेंड वैल्यू के बिट पोजिशन को राइट ऑपरेंड द्वारा निर्दिष्ट बिट्स की संख्या के द्वारा छोड़ा गया है। A << 2 240 देगा, जो कि 1111 0000 है
>> बाइनरी राइट शिफ्ट ऑपरेटर। बाएं ऑपरेंड मान के बिट पदों को दाएं ऑपरेंड द्वारा निर्दिष्ट बिट्स की संख्या से दाएं स्थानांतरित किया जाता है। A >> 2 15 देगा, जो कि 1111 है
>>> दाएं शून्य भरण ऑपरेटर को शिफ्ट करें बाएं ऑपरेंड वैल्यू को सही ऑपरेंड द्वारा निर्दिष्ट बिट्स की संख्या से दाएं स्थानांतरित किया जाता है और शिफ्ट किए गए मान शून्य से भरे जाते हैं। A >>> 2 15 देगा जो 0000 1111 है

असाइनमेंट ऑपरेटर्स

स्काला भाषा द्वारा समर्थित असाइनमेंट ऑपरेटर निम्नलिखित हैं -

उदाहरण दिखाएं

ऑपरेटर विवरण उदाहरण
= सरल असाइनमेंट ऑपरेटर, राइट साइड ऑपरेंड्स से लेफ्ट साइड ऑपरेंड तक वैल्यू असाइन करता है C = A + B A + B का C में मान प्रदान करेगा
+ = जोड़ें और असाइनमेंट ऑपरेटर, यह बाएं ऑपरेटर के लिए सही ऑपरेंड जोड़ता है और परिणाम को बाएं ऑपरेंड में असाइन करता है C + = A C = C + A के बराबर है
- = घटाव और असाइनमेंट ऑपरेटर, यह बाएं ऑपरेटर से दाएं ऑपरेंड को घटाता है और बाएं ऑपरेंड को परिणाम असाइन करता है C - = A C = C - A के बराबर है
* = गुणा और असाइनमेंट ऑपरेटर, यह बाएं ऑपरेटर के साथ दाएं ऑपरेंड को गुणा करता है और परिणाम को बाएं ऑपरेंड में असाइन करता है C * = A C = C * A के बराबर है
/ = डिवाइड और असाइनमेंट ऑपरेटर, यह बाएं ऑपरेंड को सही ऑपरेंड के साथ विभाजित करता है और परिणाम को बाएं ऑपरेंड को असाइन करता है C / = A C = C / A के बराबर है
% = मापांक और असाइनमेंट ऑपरेटर, यह दो ऑपरेंड का उपयोग करके मापांक लेता है और परिणाम को बाएं ऑपरेंड में असाइन करता है C% = A C = C% A के बराबर है
<< = लेफ्ट शिफ्ट और असाइनमेंट ऑपरेटर C << = 2 C = C << 2 के समान है
>> = राइट शिफ्ट और असाइनमेंट ऑपरेटर C >> = 2 C = C >> 2 के समान है
और = बिटवाइज और असाइनमेंट ऑपरेटर C & = 2 C = C & 2 के समान है
^ = बिटवाइज एक्सक्लूसिव OR एंड असाइनमेंट ऑपरेटर C ^ = 2 C = C ^ 2 के समान है
| = बिटवाइज समावेशी या असाइनमेंट ऑपरेटर C | = 2 C = C के समान है 2

स्काला में ऑपरेटर्स प्रिसेंस

ऑपरेटर पूर्वता एक अभिव्यक्ति में शब्दों के समूहीकरण को निर्धारित करता है। यह प्रभावित करता है कि अभिव्यक्ति का मूल्यांकन कैसे किया जाता है। कुछ ऑपरेटरों में अन्य लोगों की तुलना में अधिक पूर्वता है; उदाहरण के लिए, गुणा ऑपरेटर में अतिरिक्त ऑपरेटर की तुलना में अधिक पूर्वता है -

उदाहरण के लिए, x = 7 + 3 * 2; यहाँ, x को 13 नहीं, 20 को सौंपा गया है क्योंकि ऑपरेटर * में + से अधिक पूर्वता है, इसलिए यह पहले 3 * 2 के साथ गुणा हो जाता है और फिर 7 में जुड़ जाता है।

निम्नलिखित तालिका पर एक नज़र डालें। उच्चतम वरीयता वाले ऑपरेटर तालिका के शीर्ष पर दिखाई देते हैं और सबसे कम वरीयता वाले लोग सबसे नीचे दिखाई देते हैं। एक अभिव्यक्ति के भीतर, उच्च पूर्वता ऑपरेटरों का मूल्यांकन पहले किया जाएगा।

वर्ग ऑपरेटर संबद्धता
पोस्टफ़िक्स () [] बाएं से दाएं
एकल ! ~ दाएं से बाएं
गुणक * *% बाएं से दाएं
additive + - बाएं से दाएं
खिसक जाना >> >>> << बाएं से दाएं
रिलेशनल >> = <<= बाएं से दाएं
समानता ==! = बाएं से दाएं
बिटवाइज़ और और बाएं से दाएं
बिटवाइज़ XOR ^ बाएं से दाएं
बिटवार या | बाएं से दाएं
तार्किक और && बाएं से दाएं
तार्किक या || बाएं से दाएं
असाइनमेंट = + = - = * = / =% = >> = << = & = ^ = = | = | दाएं से बाएं
अल्पविराम , बाएं से दाएं

यह अध्याय आपको स्काला प्रोग्रामिंग में सशर्त निर्माण कथनों के माध्यम से ले जाता है। निम्नलिखित एक सामान्य निर्णय लेने का सामान्य रूप है, IF ... ELSE संरचना, जो अधिकांश प्रोग्रामिंग भाषाओं में पाई जाती है।

फ्लो चार्ट

निम्नलिखित सशर्त विवरण के लिए एक प्रवाह चार्ट आरेख है।

यदि कथन

'अगर' बयान में एक या अधिक बयानों के बाद बूलियन अभिव्यक्ति शामिल है।

वाक्य - विन्यास

'If' स्टेटमेंट का सिंटैक्स निम्नानुसार है।

if(Boolean_expression) {
   // Statements will execute if the Boolean expression is true
}

यदि बूलियन अभिव्यक्ति सही का मूल्यांकन करती है तो 'if' अभिव्यक्ति के अंदर कोड का ब्लॉक निष्पादित किया जाएगा। यदि नहीं, तो 'if' एक्सप्रेशन (समापन कर्ली ब्रेस के बाद) के अंत के बाद कोड का पहला सेट निष्पादित किया जाएगा।

स्केला प्रोग्रामिंग भाषा में सशर्त अभिव्यक्ति (यदि अभिव्यक्ति) को समझने के लिए निम्न उदाहरण कार्यक्रम का प्रयास करें।

उदाहरण

object Demo {
   def main(args: Array[String]) {
      var x = 10;

      if( x < 20 ){
         println("This is if statement");
      }
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

This is if statement

अगर-और स्टेटमेंट

एक 'अगर' बयान एक वैकल्पिक द्वारा पीछा किया जा सकता है और कुछ बयान है, जो क्रियान्वित होती है बूलियन अभिव्यक्ति गलत है।

वाक्य - विन्यास

यदि ... का सिंटैक्स है ...

if(Boolean_expression){
   //Executes when the Boolean expression is true
} else{
   //Executes when the Boolean expression is false
}

स्केला प्रोग्रामिंग लैंग्वेज में सशर्त वक्तव्यों (यदि- और स्टेटमेंट) को समझने के लिए निम्न उदाहरण प्रोग्राम का प्रयास करें।

उदाहरण

object Demo {
   def main(args: Array[String]) {
      var x = 30;

      if( x < 20 ){
         println("This is if statement");
      } else {
         println("This is else statement");
      }
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

This is else statement

इफ-इफ-इफ-इफ स्टेटमेंट

एक 'if' स्टेटमेंट को एक वैकल्पिक ' और ... if' स्टेटमेंट द्वारा फॉलो किया जा सकता है , जो कि if if का उपयोग करके विभिन्न स्थितियों का परीक्षण करने के लिए बहुत उपयोगी है ... और यदि स्टेटमेंट।

उपयोग करते समय, यदि और, तो, कुछ और बिंदुओं को ध्यान में रखना चाहिए।

  • एक 'अगर' में शून्य या एक और हो सकता है और इसे किसी और के बाद आना चाहिए।

  • एक 'अगर' कई शून्य हो सकता है अगर और वे दूसरे से पहले आना चाहिए।

  • एक बार अगर कोई सफल हो जाता है, तो बाकी में से कोई भी अगर बाकी है या नहीं, तो उसका परीक्षण किया जाएगा।

वाक्य - विन्यास

निम्नलिखित एक 'अगर ... और अगर ... और' का वाक्य विन्यास इस प्रकार है -

if(Boolean_expression 1){
   //Executes when the Boolean expression 1 is true
} else if(Boolean_expression 2){
   //Executes when the Boolean expression 2 is true
} else if(Boolean_expression 3){
   //Executes when the Boolean expression 3 is true
} else {
   //Executes when the none of the above condition is true.
}

स्केला प्रोग्रामिंग लैंग्वेज में सशर्त बयानों को समझने के लिए निम्न उदाहरण प्रोग्राम (यदि- और- अगर- और स्टेटमेंट) को आजमाएं।

उदाहरण

object Demo {
   def main(args: Array[String]) {
      var x = 30;

      if( x == 10 ){
         println("Value of X is 10");
      } else if( x == 20 ){
         println("Value of X is 20");
      } else if( x == 30 ){
         println("Value of X is 30");
      } else{
         println("This is else statement");
      }
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

Value of X is 30

नेस्ट-इफ स्टेटमेंट

यह हमेशा घोंसला बनाने के लिए कानूनी है if-else बयान, जिसका अर्थ है कि आप एक का उपयोग कर सकते हैं if या else-if दूसरे के अंदर बयान if या else-if बयान।

वाक्य - विन्यास

एक नेस्टेड के लिए सिंटैक्स यदि निम्नानुसार है -

if(Boolean_expression 1){
   //Executes when the Boolean expression 1 is true
   
   if(Boolean_expression 2){
      //Executes when the Boolean expression 2 is true
   }
}

स्केला प्रोग्रामिंग लैंग्वेज में सशर्त बयानों (नेस्टेड- इफ स्टेटमेंट) को समझने के लिए निम्न उदाहरण प्रोग्राम का प्रयास करें।

उदाहरण

object Demo {
   def main(args: Array[String]) {
      var x = 30;
      var y = 10;
      
      if( x == 30 ){
         if( y == 10 ){
            println("X = 30 and Y = 10");
         }
      }
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

X = 30 and Y = 10

यह अध्याय आपको स्केल प्रोग्रामिंग भाषाओं में लूप नियंत्रण संरचनाओं के माध्यम से ले जाता है।

एक स्थिति हो सकती है, जब आपको कई बार कोड के ब्लॉक को निष्पादित करने की आवश्यकता होती है। सामान्य तौर पर, बयानों को क्रमिक रूप से निष्पादित किया जाता है: किसी फ़ंक्शन में पहला कथन पहले निष्पादित किया जाता है, उसके बाद दूसरा, और इसी तरह।

प्रोग्रामिंग भाषाएँ विभिन्न नियंत्रण संरचनाएं प्रदान करती हैं जो अधिक जटिल निष्पादन पथों के लिए अनुमति देती हैं।

एक लूप स्टेटमेंट हमें कई बार स्टेटमेंट या स्टेटमेंट को निष्पादित करने की अनुमति देता है और निम्नलिखित प्रोग्रामिंग भाषाओं में से एक लूप स्टेटमेंट का सामान्य रूप है -

फ्लो चार्ट

स्केल प्रोग्रामिंग भाषा लूपिंग आवश्यकताओं को संभालने के लिए निम्न प्रकार के लूप प्रदान करती है। उनके विवरण की जांच करने के लिए तालिका में निम्नलिखित लिंक पर क्लिक करें।

अनु क्रमांक लूप प्रकार और विवरण
1

while loop

एक बयान या बयानों के समूह को दोहराता है जबकि किसी दिए गए शर्त सही है। यह लूप बॉडी को निष्पादित करने से पहले स्थिति का परीक्षण करता है।

2

do-while loop

थोड़ी देर के बयान की तरह, सिवाय इसके कि यह लूप बॉडी के अंत में स्थिति का परीक्षण करता है।

3

for loop

कई बार बयानों का क्रम निष्पादित करता है और उस कोड को संक्षिप्त करता है जो लूप चर का प्रबंधन करता है।

लूप नियंत्रण विवरण

लूप नियंत्रण स्टेटमेंट अपने सामान्य अनुक्रम से निष्पादन को बदल देता है। जब निष्पादन एक गुंजाइश छोड़ देता है, तो उस दायरे में बनाए गए सभी स्वचालित ऑब्जेक्ट नष्ट हो जाते हैं। जैसा कि स्काला समर्थन नहीं करता हैbreak या continueजावा जैसा कथन करता है, लेकिन स्केल संस्करण 2.8 से शुरू होकर, लूप को तोड़ने का एक तरीका है। विवरण की जांच करने के लिए निम्नलिखित लिंक पर क्लिक करें।

अनु क्रमांक नियंत्रण विवरण और विवरण
1

break statement

टर्मिनेट करता है loop बयान और लूप के तुरंत बाद स्टेटमेंट को ट्रांसफर कर देता है।

अनंत लूप

एक लूप एक अनंत लूप बन जाता है अगर कोई स्थिति कभी झूठी न हो। यदि आप स्काला का उपयोग कर रहे हैं,while लूप अनंत लूप को लागू करने का सबसे अच्छा तरीका है।

निम्नलिखित कार्यक्रम अनंत लूप को लागू करता है।

उदाहरण

object Demo {
   def main(args: Array[String]) {
      var a = 10;
      
      // An infinite loop.
      while( true ){
         println( "Value of a: " + a );
      }
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

यदि आप कोड से ऊपर निष्पादित करेंगे, तो यह अनंत लूप में जाएगा जिसे आप Ctrl + C कीज़ दबाकर समाप्त कर सकते हैं।

Value of a: 10
Value of a: 10
Value of a: 10
Value of a: 10
…………….

एक फ़ंक्शन स्टेटमेंट का एक समूह है जो एक कार्य करता है। आप अपने कोड को अलग-अलग कार्यों में विभाजित कर सकते हैं। आप विभिन्न कार्यों के बीच अपने कोड को कैसे विभाजित करते हैं, यह आपके ऊपर है, लेकिन तार्किक रूप से, विभाजन आमतौर पर ऐसा होता है कि प्रत्येक फ़ंक्शन एक विशिष्ट कार्य करता है।

स्काला के कार्य और विधियां दोनों हैं और हम एक मामूली अंतर के साथ शब्द विधि और कार्य का परस्पर उपयोग करते हैं। स्काला पद्धति एक वर्ग का एक हिस्सा है जिसमें एक नाम, एक हस्ताक्षर, वैकल्पिक रूप से कुछ एनोटेशन और कुछ बायोटेक होते हैं, जहां स्काला में एक फ़ंक्शन के रूप में एक पूर्ण वस्तु है जिसे एक चर को सौंपा जा सकता है। दूसरे शब्दों में, एक फ़ंक्शन, जिसे किसी वस्तु के सदस्य के रूप में परिभाषित किया जाता है, एक विधि कहा जाता है।

एक फ़ंक्शन परिभाषा एक स्रोत फ़ाइल में कहीं भी दिखाई दे सकती है और स्काला नेस्टेड फंक्शन परिभाषाओं को अनुमति देता है, अर्थात, फ़ंक्शन फ़ंक्शन को अन्य फ़ंक्शन परिभाषाओं के अंदर। ध्यान देने वाली सबसे महत्वपूर्ण बात यह है कि स्काला फ़ंक्शन के नाम में +, ++, ~, &, -, -, -, \, /,:, आदि जैसे अक्षर हो सकते हैं।

समारोह घोषणाएँ

एक स्कैला फ़ंक्शन घोषणा के निम्नलिखित रूप हैं -

def functionName ([list of parameters]) : [return type]

यदि आप समान चिह्न और विधि निकाय का उपयोग नहीं करते हैं तो विधियाँ स्पष्ट रूप से सार घोषित की जाती हैं ।

कार्य परिभाषाएँ

स्केल फ़ंक्शन की परिभाषा निम्न रूप में है -

वाक्य - विन्यास

def functionName ([list of parameters]) : [return type] = {
   function body
   return [expr]
}

यहाँ, return type कोई भी मान्य स्काला डेटा प्रकार और हो सकता है list of parametersअल्पविराम द्वारा अलग किए गए चर की एक सूची होगी और मापदंडों और वापसी प्रकार की सूची वैकल्पिक है। जावा के समान, एreturnस्टेटमेंट फंक्शन रिटर्न में एक वैल्यू के साथ स्टेटमेंट का इस्तेमाल किया जा सकता है। निम्नलिखित कार्य है जो दो पूर्णांक जोड़ेंगे और उनकी राशि लौटाएंगे -

वाक्य - विन्यास

object add {
   def addInt( a:Int, b:Int ) : Int = {
      var sum:Int = 0
      sum = a + b
      return sum
   }
}

एक फ़ंक्शन, जो कुछ भी वापस नहीं करता है एक वापस कर सकता है Unit के बराबर है voidजावा में और इंगित करता है कि फ़ंक्शन कुछ भी वापस नहीं करता है। वे कार्य जो स्काला में कुछ भी वापस नहीं करते हैं, उन्हें प्रक्रिया कहा जाता है।

वाक्य - विन्यास

यहाँ वाक्य रचना है -

object Hello{
   def printMe( ) : Unit = {
      println("Hello, Scala!")
   }
}

कॉलिंग फ़ंक्शंस

स्काला आह्वान करने के तरीकों के लिए कई वाक्यात्मक विविधताएं प्रदान करता है। विधि को कॉल करने का मानक तरीका निम्नलिखित है -

functionName( list of parameters )

यदि किसी वस्तु के उदाहरण का उपयोग करके किसी फ़ंक्शन को बुलाया जा रहा है, तो हम जावा के समान डॉट नोटेशन का उपयोग करेंगे -

[instance.]functionName( list of parameters )

परिभाषित करने के लिए निम्न उदाहरण कार्यक्रम का प्रयास करें और फिर उसी फ़ंक्शन को कॉल करें।

उदाहरण

object Demo {
   def main(args: Array[String]) {
      println( "Returned Value : " + addInt(5,7) );
   }
   
   def addInt( a:Int, b:Int ) : Int = {
      var sum:Int = 0
      sum = a + b

      return sum
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

Returned Value : 12

स्काला फ़ंक्शंस स्काला प्रोग्रामिंग का दिल हैं और इसीलिए स्काला को एक कार्यात्मक प्रोग्रामिंग भाषा के रूप में ग्रहण किया जाता है। स्काला फ़ंक्शंस से संबंधित कुछ महत्वपूर्ण अवधारणाएँ निम्नलिखित हैं जिन्हें एक स्काला प्रोग्रामर द्वारा समझा जाना चाहिए।

कॉल-बाय-नेम नामित तर्क के साथ कार्य
चर तर्क के साथ कार्य पुनरावर्तन कार्य
डिफ़ॉल्ट पैरामीटर मान उच्च-क्रम के कार्य
नेस्टेड कार्य अनाम कार्य
आंशिक रूप से लागू कार्य करी क्रिया

closure एक फ़ंक्शन है, जिसका रिटर्न मान इस फ़ंक्शन के बाहर घोषित एक या अधिक चर के मूल्य पर निर्भर करता है।

अनाम फ़ंक्शन के साथ कोड का निम्नलिखित टुकड़ा।

val multiplier = (i:Int) => i * 10

यहां फ़ंक्शन बॉडी में उपयोग किया जाने वाला एकमात्र वैरिएबल, i * 10, i है, जिसे फ़ंक्शन के पैरामीटर के रूप में परिभाषित किया गया है। निम्नलिखित कोड का प्रयास करें -

val multiplier = (i:Int) => i * factor

गुणक में दो मुक्त चर हैं: i तथा factor। उनमें से एक, i, फ़ंक्शन के लिए एक औपचारिक पैरामीटर है। इसलिए, इसे हर बार एक नए मूल्य के लिए बाध्य किया जाता है जिसे गुणक कहा जाता है। तथापि,factorएक औपचारिक पैरामीटर नहीं है, तो यह क्या है? कोड की एक और पंक्ति जोड़ते हैं।

var factor = 3
val multiplier = (i:Int) => i * factor

अभी factorफ़ंक्शन के बाहर एक वैरिएबल का संदर्भ होता है लेकिन एन्कोडिंग क्षेत्र में। फ़ंक्शन संदर्भfactorऔर हर बार इसके वर्तमान मूल्य को पढ़ता है। यदि किसी फ़ंक्शन का कोई बाहरी संदर्भ नहीं है, तो यह अपने आप में तुच्छ रूप से बंद है। किसी बाहरी संदर्भ की आवश्यकता नहीं है।

निम्नलिखित उदाहरण कार्यक्रम का प्रयास करें।

उदाहरण

object Demo {
   def main(args: Array[String]) {
      println( "multiplier(1) value = " +  multiplier(1) )
      println( "multiplier(2) value = " +  multiplier(2) )
   }
   var factor = 3
   val multiplier = (i:Int) => i * factor
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

multiplier(1) value = 3
multiplier(2) value = 6

यह अध्याय आपको स्काला स्ट्रिंग्स के माध्यम से ले जाता है। जावा की तरह स्काला में, एक स्ट्रिंग एक अपरिवर्तनीय वस्तु है, अर्थात, एक ऐसी वस्तु जिसे संशोधित नहीं किया जा सकता है। दूसरी ओर, जिन वस्तुओं को संशोधित किया जा सकता है, जैसे सरणियाँ, उत्परिवर्तित वस्तुएं कहलाती हैं। स्ट्रिंग्स बहुत उपयोगी वस्तुएं हैं, इस भाग के बाकी हिस्सों में, हम महत्वपूर्ण तरीके प्रस्तुत करते हैंjava.lang.String कक्षा।

एक स्ट्रिंग बनाना

स्ट्रिंग बनाने के लिए निम्न कोड का उपयोग किया जा सकता है -

var greeting = "Hello world!";

or

var greeting:String = "Hello world!";

जब भी संकलक कोड में एक स्ट्रिंग शाब्दिक का सामना करता है, तो वह अपने मूल्य के साथ एक स्ट्रिंग ऑब्जेक्ट बनाता है, इस मामले में "हैलो वर्ल्ड!"। जैसा कि ऊपर दिखाया गया है, स्ट्रिंग कीवर्ड को वैकल्पिक घोषणा में भी दिया जा सकता है।

निम्नलिखित उदाहरण कार्यक्रम का प्रयास करें।

उदाहरण

object Demo {
   val greeting: String = "Hello, world!"

   def main(args: Array[String]) {
      println( greeting )
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

Hello, world!

जैसा कि पहले उल्लेख किया गया है, स्ट्रिंग वर्ग अपरिवर्तनीय है। स्ट्रिंग ऑब्जेक्ट एक बार बनाया नहीं बदला जा सकता है। यदि पात्रों के स्ट्रिंग्स में बहुत सारे संशोधन करने की आवश्यकता है, तो स्केला में उपलब्ध स्ट्रिंग बिल्डर क्लास का उपयोग करें।

स्ट्रिंग लंबाई

किसी वस्तु के बारे में जानकारी प्राप्त करने के लिए उपयोग की जाने वाली विधियाँ अभिगम विधियों के रूप में जानी जाती हैं। एक एक्सेसर विधि जिसे स्ट्रिंग्स के साथ इस्तेमाल किया जा सकता है, वह लंबाई () विधि है, जो स्ट्रिंग ऑब्जेक्ट में निहित वर्णों की संख्या लौटाती है।

स्ट्रिंग की लंबाई ज्ञात करने के लिए निम्नलिखित कोड सेगमेंट का उपयोग करें -

उदाहरण

object Demo {
   def main(args: Array[String]) {
      var palindrome = "Dot saw I was Tod";
      var len = palindrome.length();
      
      println( "String Length is : " + len );
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

String Length is : 17

कॉनटेटनेटिंग स्ट्रिंग्स

स्ट्रिंग क्लास में दो तारों को समेटने की एक विधि शामिल है -

string1.concat(string2);

यह एक नया स्ट्रिंग देता है जो string2 string2 के साथ इसे अंत में जोड़ा गया है। आप स्ट्रिंग शाब्दिक के साथ कॉनकट () विधि का भी उपयोग कर सकते हैं, जैसे कि -

"My name is ".concat("Zara");

स्ट्रिंग्स को आमतौर पर + ऑपरेटर के साथ जोड़ा जाता है, जैसे कि -

"Hello," + " world" + "!"

जिसके परिणामस्वरूप -

"Hello, world!"

स्ट्रिंग की लंबाई खोजने के लिए कोड की निम्नलिखित पंक्तियाँ।

उदाहरण

object Demo {
   def main(args: Array[String]) {
      var str1 = "Dot saw I was ";
      var str2 =  "Tod";
      
      println("Dot " + str1 + str2);
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

Dot Dot saw I was Tod

प्रारूप स्ट्रिंग्स बनाना

आपके पास स्वरूपित संख्याओं के साथ आउटपुट प्रिंट करने के लिए प्रिंटफ () और प्रारूप () तरीके हैं। स्ट्रिंग क्लास में समतुल्य वर्ग विधि, प्रारूप () होता है, जो PrintStream ऑब्जेक्ट के बजाय स्ट्रिंग ऑब्जेक्ट देता है।

निम्नलिखित उदाहरण कार्यक्रम का प्रयास करें, जो प्रिंटफ () विधि का उपयोग करता है -

उदाहरण

object Demo {
   def main(args: Array[String]) {
      var floatVar = 12.456
      var intVar = 2000
      var stringVar = "Hello, Scala!"
      
      var fs = printf("The value of the float variable is " + "%f, while the value of the integer " + "variable is %d, and the string" + "is %s", floatVar, intVar, stringVar);
      
      println(fs)
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

The value of the float variable is 12.456000, 
while the value of the integer variable is 2000, 
and the string is Hello, Scala!()

स्ट्रिंग इंटरपोल

स्ट्रिंग प्रोग्रामिंग भाषा में प्रोग्रामिंग प्रोग्रामिंग भाषा में स्ट्रिंग्स बनाने का नया तरीका है। यह सुविधा स्कैला -2.0 और बाद के संस्करणों का समर्थन करती है। स्ट्रिंग इंटरपोलेशन: प्रक्रिया स्ट्रिंग स्ट्रिंग शाब्दिक में सीधे चर संदर्भ एम्बेड करने के लिए।

स्ट्रिंग इंटरपोल में कार्यान्वयन के तीन प्रकार (प्रक्षेपक) हैं।

स्ट्रिंग इंटरपोलर

शाब्दिक 's' एक स्ट्रिंग को संसाधित करने में सीधे चर के उपयोग की अनुमति देता है, जब आप इसे 's' के लिए प्रस्तुत करते हैं। एक स्ट्रिंग के साथ कोई भी स्ट्रिंग चर जिसका उपयोग स्ट्रिंग में किया जा सकता है। निम्नलिखित 's' स्ट्रिंग इंटरपोलर के विभिन्न उपयोग हैं।

निम्न उदाहरण कोड को लागू करने के लिए 's' इंटरपोलर के कार्यान्वयन के लिए स्ट्रिंग वेरिएबल ($ नाम) को प्रिंटनल स्टेटमेंट में एक सामान्य स्ट्रिंग (हैलो) के लिए।

val name = “James”
println(s “Hello, $name”) //output: Hello, James

स्ट्रिंग इंटरपोलर भी मनमाने ढंग से अभिव्यक्ति की प्रक्रिया कर सकता है। निम्नलिखित कोड स्निपेट को एक स्ट्रिंग (1 + 1) प्रसंस्करण के लिए मनमाने ढंग से अभिव्यक्ति ($ {1 + 1}) के साथ 's' स्ट्रिंग इंटरपोलर का उपयोग कर। किसी भी मनमानी अभिव्यक्ति को '$ {}' में एम्बेड किया जा सकता है।

println(s “1 + 1 = ${1 + 1}”) //output: 1 + 1 = 2

'S' इंटरपोलर को लागू करने के निम्नलिखित उदाहरण कार्यक्रम का प्रयास करें।

उदाहरण

object Demo {
   def main(args: Array[String]) {
      val name = "James"
      
      println(s"Hello, $name") println(s"1 + 1 = ${1 + 1}")
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

Hello, James
1 + 1 = 2

'च' इंटरपोलर

शाब्दिक 'एफ' इंटरपोलर सी भाषा में प्रिंटफ के समान एक प्रारूपित स्ट्रिंग बनाने की अनुमति देता है। 'एफ' इंटरपोलर का उपयोग करते समय, सभी चर संदर्भों का पालन किया जाना चाहिएprintf शैली प्रारूप निर्दिष्टकर्ता जैसे% d,% i,% f, आदि।

आइए हम सामान्य स्ट्रिंग के साथ एपेंड फ्लोटिंग पॉइंट वैल्यू (ऊंचाई = 1.9d) और स्ट्रिंग चर (नाम = "जेम्स") का एक उदाहरण लेते हैं। निम्नलिखित कोड 'एफ' इंटरपोलर को लागू करने का स्निपेट है। यहाँ$name%s to print (String variable) James and $ऊँचाई% 2.2f प्रिंट करने के लिए (फ्लोटिंग पॉइंट वैल्यू) 1.90।

val height = 1.9d
val name = "James"
println(f"$name%s is $height%2.2f meters tall") //James is 1.90 meters tall

यह प्रकार सुरक्षित है (यानी) चर संदर्भ और निम्न प्रारूप विनिर्देशक से मेल खाना चाहिए अन्यथा यह त्रुटि दिखा रहा है। जावा में उपलब्ध स्ट्रिंग प्रारूप उपयोगिताओं (प्रारूप विनिर्देशक) का 'एफ' इंटरपोलर उपयोग करता है। डिफ़ॉल्ट रूप से, चर संदर्भ के बाद कोई% वर्ण नहीं है। यह% s (स्ट्रिंग) के रूप में माना जाएगा।

'रॉ' इंटरपोलर

'रॉ' इंटरपोलर 'एस' इंटरपोलर के समान है, सिवाय इसके कि यह स्ट्रिंग के भीतर शाब्दिक रूप से बचने का कार्य नहीं करता है। एक टेबल में निम्नलिखित कोड स्निपेट 's' और 'रॉ' इंटरपोलर के उपयोग को अलग करेगा। नई लाइन के रूप में 's' यूज़ '\ n' इफेक्ट्स के आउटपुट में और 'रॉ' यूज़ के '' एन '' आउटपुट पर असर नहीं पड़ेगा। यह भागने के पत्रों के साथ पूरा स्ट्रिंग प्रिंट करेगा।

इंटरपोलर का उपयोग 'कच्चे' इंटरपोलर उपयोग

Program -

object Demo {
   def main(args: Array[String]) {
      println(s"Result = \n a \n b")
   }
}

Program -

object Demo {
   def main(args: Array[String]) {
      println(raw"Result = \n a \n b")
   }
}

Output -

Result =
a
b

Output -

Result = \n a \n b

स्ट्रिंग के तरीके

निम्नलिखित तरीकों की सूची द्वारा परिभाषित किया गया है java.lang.String वर्ग और सीधे अपने स्काला कार्यक्रमों में इस्तेमाल किया जा सकता है -

अनु क्रमांक विवरण के साथ तरीके
1

char charAt(int index)

निर्दिष्ट सूचकांक पर चरित्र लौटाता है।

2

int compareTo(Object o)

इस स्ट्रिंग की तुलना किसी अन्य ऑब्जेक्ट से करता है।

3

int compareTo(String anotherString)

तुलनात्मक रूप से दो तारों की तुलना करता है।

4

int compareToIgnoreCase(String str)

मामले के अंतर को नजरअंदाज करते हुए, दो तारों की तुलनात्मक रूप से करें।

5

String concat(String str)

इस स्ट्रिंग के अंत तक निर्दिष्ट स्ट्रिंग को समेटता है।

6

boolean contentEquals(StringBuffer sb)

यह और स्ट्रिंग केवल निर्दिष्ट स्ट्रिंगर के रूप में वर्णों के समान अनुक्रम का प्रतिनिधित्व करता है, तो ही सच है।

7

static String copyValueOf(char[] data)

निर्दिष्ट क्रम में वर्ण क्रम का प्रतिनिधित्व करने वाले स्ट्रिंग को लौटाता है।

8

static String copyValueOf(char[] data, int offset, int count)

निर्दिष्ट क्रम में वर्ण क्रम का प्रतिनिधित्व करने वाले स्ट्रिंग को लौटाता है।

9

boolean endsWith(String suffix)

टेस्ट यदि यह स्ट्रिंग निर्दिष्ट प्रत्यय के साथ समाप्त होती है।

10

boolean equals(Object anObject)

इस स्ट्रिंग की तुलना निर्दिष्ट ऑब्जेक्ट से करता है।

1 1

boolean equalsIgnoreCase(String anotherString)

इस स्ट्रिंग की तुलना किसी अन्य स्ट्रिंग से करते हैं, मामले के विचारों की अनदेखी करते हुए।

12

byte getBytes()

प्लेटफ़ॉर्म के डिफ़ॉल्ट चारसेट का उपयोग करके इस स्ट्रिंग को बाइट्स के अनुक्रम में एन्कोड करता है, परिणाम को एक नई बाइट सरणी में संग्रहीत करता है।

13

byte[] getBytes(String charsetName)

इस स्ट्रिंग को एक बाइट्स के अनुक्रम में नामांकित चारसेट का उपयोग करके, परिणाम को एक नई बाइट सरणी में संग्रहीत करता है।

14

void getChars(int srcBegin, int srcEnd, char[] dst, int dstBegin)

इस स्ट्रिंग के पात्रों को गंतव्य वर्ण सरणी में कॉपी करता है।

15

int hashCode()

इस स्ट्रिंग के लिए एक हैश कोड देता है।

16

int indexOf(int ch)

निर्दिष्ट वर्ण की पहली घटना के इस स्ट्रिंग के भीतर सूचकांक लौटाता है।

17

int indexOf(int ch, int fromIndex)

निर्दिष्ट वर्ण पर खोज शुरू करने, निर्दिष्ट चरित्र की पहली घटना के इस स्ट्रिंग के भीतर सूचकांक लौटाता है।

18

int indexOf(String str)

निर्दिष्ट सबस्ट्रिंग की पहली घटना के इस स्ट्रिंग के भीतर सूचकांक लौटाता है।

19

int indexOf(String str, int fromIndex)

निर्दिष्ट इंडेक्स पर शुरू होने वाले निर्दिष्ट सबरिंग की पहली घटना के इस सूचकांक के भीतर इंडेक्स लौटाता है।

20

String intern()

स्ट्रिंग ऑब्जेक्ट के लिए एक विहित प्रतिनिधित्व लौटाता है।

21

int lastIndexOf(int ch)

निर्दिष्ट वर्ण की अंतिम घटना के इस स्ट्रिंग के भीतर सूचकांक लौटाता है।

22

int lastIndexOf(int ch, int fromIndex)

निर्दिष्ट वर्ण की पिछली घटना के इस स्ट्रिंग के भीतर सूचकांक को वापस करता है, निर्दिष्ट सूचकांक पर पिछड़े हुए खोज की शुरुआत करता है।

23

int lastIndexOf(String str)

निर्दिष्ट स्ट्रिंग की सही घटना के इस स्ट्रिंग के भीतर सूचकांक लौटाता है।

24

int lastIndexOf(String str, int fromIndex)

निर्दिष्ट प्रतिस्थापन की अंतिम घटना की इस स्ट्रिंग के भीतर सूचकांक को वापस करता है, निर्दिष्ट सूचकांक पर पीछे की ओर खोज शुरू करता है।

25

int length()

इस स्ट्रिंग की लंबाई लौटाता है।

26

boolean matches(String regex)

बताता है कि यह स्ट्रिंग दी गई नियमित अभिव्यक्ति से मेल खाती है या नहीं।

27

boolean regionMatches(boolean ignoreCase, int toffset, String other, int offset, int len)

यदि दो स्ट्रिंग क्षेत्र बराबर हैं तो टेस्ट।

28

boolean regionMatches(int toffset, String other, int offset, int len)

यदि दो स्ट्रिंग क्षेत्र बराबर हैं तो टेस्ट।

29

String replace(char oldChar, char newChar)

नए तार में पुराने स्ट्रिंग की सभी घटनाओं को बदलने के परिणामस्वरूप एक नया स्ट्रिंग लौटाता है।

30

String replaceAll(String regex, String replacement

इस स्ट्रिंग के प्रत्येक प्रतिस्थापन को प्रतिस्थापित करता है जो दिए गए प्रतिस्थापन के साथ दिए गए नियमित अभिव्यक्ति से मेल खाता है।

31

String replaceFirst(String regex, String replacement)

इस स्ट्रिंग के पहले प्रतिस्थापन को प्रतिस्थापित करता है जो दिए गए प्रतिस्थापन के साथ दिए गए नियमित अभिव्यक्ति से मेल खाता है।

32

String[] split(String regex)

इस स्ट्रिंग को दिए गए रेगुलर एक्सप्रेशन के मैचों के आसपास विभाजित करता है।

33

String[] split(String regex, int limit)

इस स्ट्रिंग को दिए गए रेगुलर एक्सप्रेशन के मैचों के आसपास विभाजित करता है।

34

boolean startsWith(String prefix)

यदि यह स्ट्रिंग निर्दिष्ट उपसर्ग के साथ शुरू होती है तो टेस्ट।

35

boolean startsWith(String prefix, int toffset)

यदि यह स्ट्रिंग निर्दिष्ट सूचकांक के साथ निर्दिष्ट उपसर्ग के साथ शुरू होती है तो टेस्ट।

36

CharSequence subSequence(int beginIndex, int endIndex)

एक नया चरित्र अनुक्रम लौटाता है जो इस अनुक्रम का एक क्रम है।

37

String substring(int beginIndex)

एक नया स्ट्रिंग लौटाता है जो इस स्ट्रिंग का एक विकल्प है।

38

String substring(int beginIndex, int endIndex)

एक नया स्ट्रिंग लौटाता है जो इस स्ट्रिंग का एक विकल्प है।

39

char[] toCharArray()

इस स्ट्रिंग को एक नए वर्ण सरणी में परिवर्तित करता है।

40

String toLowerCase()

इस स्ट्रिंग के सभी वर्णों को डिफ़ॉल्ट लोकेल के नियमों का उपयोग करके निचले मामले में परिवर्तित करता है।

41

String toLowerCase(Locale locale)

इस स्ट्रिंग के सभी वर्णों को दिए गए लोकेले के नियमों का उपयोग करके निचले मामले में परिवर्तित करता है।

42

String toString()

यह ऑब्जेक्ट (जो पहले से ही एक स्ट्रिंग है!) खुद ही वापस आ गया है।

43

String toUpperCase()

इस स्ट्रिंग के सभी वर्णों को डिफ़ॉल्ट लोकेल के नियमों का उपयोग करके ऊपरी मामले में कनवर्ट करता है।

44

String toUpperCase(Locale locale)

इस स्ट्रिंग के सभी पात्रों को ऊपरी स्थान में दिए गए स्थान के नियमों का उपयोग करके परिवर्तित करता है।

45

String trim()

स्ट्रिंग की एक प्रतिलिपि लौटाता है, जिसके साथ व्हाट्सएप लोप हो जाता है।

46

static String valueOf(primitive data type x)

पारित डेटा प्रकार के तर्क का स्ट्रिंग प्रतिनिधित्व लौटाता है।

स्काला डेटा संरचना प्रदान करता है array, जो एक ही प्रकार के तत्वों के एक निश्चित आकार के अनुक्रमिक संग्रह को संग्रहीत करता है। एक सरणी का उपयोग डेटा के संग्रह को संग्रहीत करने के लिए किया जाता है, लेकिन एक सरणी के एक ही प्रकार के संग्रह के रूप में सरणी के बारे में सोचना अक्सर अधिक उपयोगी होता है।

नंबर चर, नंबर 1, ... और नंबर 99 जैसे अलग-अलग चर घोषित करने के बजाय, आप एक सरणी चर जैसे संख्याओं की घोषणा करते हैं और संख्याओं का उपयोग करते हैं [0], संख्याओं [1] और ..., संख्याओं [99] का प्रतिनिधित्व करने के लिए। अलग-अलग चर। यह ट्यूटोरियल ऐरे वेरिएबल्स को घोषित करने, एरेज़ बनाने और इंडेक्सेड वेरिएबल्स का उपयोग करके एरेज़ को प्रोसेस करने का तरीका बताता है। किसी सरणी के पहले तत्व का सूचकांक संख्या शून्य है और अंतिम तत्व का सूचकांक तत्वों की कुल संख्या है।

ऐरे वेरिएबल की घोषणा

किसी प्रोग्राम में एरे का उपयोग करने के लिए, आपको ऐरे के संदर्भ के लिए एक वैरिएबल की घोषणा करनी चाहिए और आपको उस प्रकार के ऐरे को निर्दिष्ट करना होगा जिसे वेरिएबल रेफर कर सकता है।

सरणी चर घोषित करने के लिए निम्नलिखित सिंटैक्स है।

वाक्य - विन्यास

var z:Array[String] = new Array[String](3)

or

var z = new Array[String](3)

यहां, z को स्ट्रिंग्स की एक सरणी के रूप में घोषित किया गया है जो तीन तत्वों तक हो सकती है। मूल्यों को व्यक्तिगत तत्वों को सौंपा जा सकता है या व्यक्तिगत तत्वों तक पहुंच प्राप्त की जा सकती है, यह निम्नलिखित जैसे आदेशों का उपयोग करके किया जा सकता है -

आदेश

z(0) = "Zara"; z(1) = "Nuha"; z(4/2) = "Ayan"

यहां, अंतिम उदाहरण से पता चलता है कि सामान्य रूप से सूचकांक कोई भी अभिव्यक्ति हो सकती है जो एक संपूर्ण संख्या प्राप्त करती है। एक सरणी को परिभाषित करने का एक और तरीका है -

var z = Array("Zara", "Nuha", "Ayan")

निम्नलिखित चित्र एक सरणी का प्रतिनिधित्व करता है myList। यहाँ,myList दस दोहरे मान रखता है और सूचकांक 0 से 9 तक हैं।

प्रसंस्करण

सरणी तत्वों को संसाधित करते समय, हम अक्सर लूप कंटोल संरचनाओं का उपयोग करते हैं क्योंकि एक सरणी में सभी तत्व एक ही प्रकार के होते हैं और सरणी का आकार ज्ञात होता है।

नीचे एक उदाहरण दिखाया गया है कि कैसे बनायें, आरंभ करें और प्रक्रिया करें -

उदाहरण

object Demo {
   def main(args: Array[String]) {
      var myList = Array(1.9, 2.9, 3.4, 3.5)
      
      // Print all the array elements
      for ( x <- myList ) {
         println( x )
      }

      // Summing all elements
      var total = 0.0;
      
      for ( i <- 0 to (myList.length - 1)) {
         total += myList(i);
      }
      println("Total is " + total);

      // Finding the largest element
      var max = myList(0);
      
      for ( i <- 1 to (myList.length - 1) ) {
         if (myList(i) > max) max = myList(i);
      }
      
      println("Max is " + max);
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

1.9
2.9
3.4
3.5
Total is 11.7
Max is 3.5

स्काला विभिन्न सरणी परिचालनों का सीधे समर्थन नहीं करता है और किसी भी आयाम में सरणियों को संसाधित करने के लिए विभिन्न तरीके प्रदान करता है। यदि आप विभिन्न तरीकों का उपयोग करना चाहते हैं तो आयात करना आवश्यक हैArray._ पैकेज।

मल्टी-डायमेंशनल एरे

ऐसी कई स्थितियाँ हैं जहाँ आपको बहुआयामी सरणियों को परिभाषित करने और उनका उपयोग करने की आवश्यकता होगी (जैसे, सरणियाँ जिनके तत्व सरणियाँ हैं)। उदाहरण के लिए, मैट्रिसेस और टेबल संरचनाओं के उदाहरण हैं जिन्हें दो-आयामी सरणियों के रूप में महसूस किया जा सकता है।

निम्नलिखित एक दो आयामी सरणी को परिभाषित करने का उदाहरण है -

var myMatrix = ofDim[Int](3,3)

यह एक ऐसा सरणी है जिसमें तीन तत्व होते हैं जिसमें प्रत्येक पूर्णांक का एक सरणी होता है जिसमें तीन तत्व होते हैं।

बहुआयामी सरणी को संसाधित करने के लिए निम्न उदाहरण प्रोग्राम का प्रयास करें -

उदाहरण

import Array._

object Demo {
   def main(args: Array[String]) {
      var myMatrix = ofDim[Int](3,3)
      
      // build a matrix
      for (i <- 0 to 2) {
         for ( j <- 0 to 2) {
            myMatrix(i)(j) = j;
         }
      }
      
      // Print two dimensional array
      for (i <- 0 to 2) {
         for ( j <- 0 to 2) {
            print(" " + myMatrix(i)(j));
         }
         println();
      }
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

0 1 2
0 1 2
0 1 2

कॉनराटेट एरेट्स

निम्नलिखित उदाहरण का प्रयास करें जो दो सरणियों को संक्षिप्त करने के लिए कॉनैट () विधि का उपयोग करता है। आप समवर्ती () विधि के तर्क के रूप में एक से अधिक सरणी पास कर सकते हैं।

उदाहरण

import Array._

object Demo {
   def main(args: Array[String]) {
      var myList1 = Array(1.9, 2.9, 3.4, 3.5)
      var myList2 = Array(8.9, 7.9, 0.4, 1.5)

      var myList3 =  concat( myList1, myList2)
      
      // Print all the array elements
      for ( x <- myList3 ) {
         println( x )
      }
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

1.9
2.9
3.4
3.5
8.9
7.9
0.4
1.5

श्रेणी के साथ सरणी बनाएँ

किसी श्रेणी में बढ़ते पूर्णांक के अनुक्रम वाले सरणी को उत्पन्न करने के लिए रेंज () विधि का उपयोग। आप अनुक्रम बनाने के लिए चरण के रूप में अंतिम तर्क का उपयोग कर सकते हैं; यदि आप अंतिम तर्क का उपयोग नहीं करते हैं, तो चरण 1 माना जाएगा।

आइए हम एक अरेंजमेंट ऑफ़ रेंज (10, 20, 2) बनाने का एक उदाहरण लेते हैं: इसका मतलब है कि 10 और 20 और रेंज फ़र्क के बीच के तत्वों के साथ एक ऐरे बनाना। एरे में तत्व 10, 12, 14, 16 और 18 हैं ।

एक और उदाहरण: रेंज (10, 20)। यहाँ श्रेणी अंतर को डिफ़ॉल्ट रूप से नहीं दिया गया है क्योंकि यह 1 तत्व मानता है। यह श्रेणी अंतर के साथ 10 और 20 के बीच तत्वों के साथ एक सरणी बनाता है। सरणी में तत्व 10, 11, 12, 13,…, और 19 हैं।

निम्न उदाहरण कार्यक्रम दिखाता है कि श्रेणियों के साथ एक सरणी कैसे बनाई जाए।

उदाहरण

import Array._

object Demo {
   def main(args: Array[String]) {
      var myList1 = range(10, 20, 2)
      var myList2 = range(10,20)

      // Print all the array elements
      for ( x <- myList1 ) {
         print( " " + x )
      }
      
      println()
      for ( x <- myList2 ) {
         print( " " + x )
      }
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

10 12 14 16 18
10 11 12 13 14 15 16 17 18 19

स्काला ऐरे तरीके

निम्नलिखित महत्वपूर्ण विधियाँ हैं, जिनका उपयोग आप सरणी के साथ खेलते समय कर सकते हैं। जैसा कि ऊपर दिखाया गया है, आपको आयात करना होगाArray._किसी भी तरीके का उपयोग करने से पहले पैकेज। उपलब्ध विधियों की पूरी सूची के लिए, कृपया स्काला के आधिकारिक दस्तावेज की जाँच करें।

अनु क्रमांक विवरण के साथ तरीके
1

def apply( x: T, xs: T* ): Array[T]

टी ऑब्जेक्ट की एक सरणी बनाता है, जहां टी यूनिट, डबल, फ्लोट, लॉन्ग, इंट, चार, शॉर्ट, बाइट, बूलियन हो सकता है।

2

def concat[T]( xss: Array[T]* ): Array[T]

सभी सरणियों को एक एकल सरणी में सम्‍मिलित करता है।

3

def copy( src: AnyRef, srcPos: Int, dest: AnyRef, destPos: Int, length: Int ): Unit

एक सरणी को दूसरे में कॉपी करें। जावा के System.arraycopy (src, srcPos, dest, destPos, length) के बराबर।

4

def empty[T]: Array[T]

लंबाई की एक सरणी देता है 0

5

def iterate[T]( start: T, len: Int )( f: (T) => T ): Array[T]

किसी सरणी को किसी फ़ंक्शन के बार-बार शुरू होने वाले एप्लिकेशन पर लौटाता है।

6

def fill[T]( n: Int )(elem: => T): Array[T]

एक सरणी देता है जिसमें कुछ तत्व गणना के परिणाम कई बार होते हैं।

7

def fill[T]( n1: Int, n2: Int )( elem: => T ): Array[Array[T]]

एक दो-आयामी सरणी देता है जिसमें कुछ तत्व संगणना के परिणाम कई बार होते हैं।

8

def iterate[T]( start: T, len: Int)( f: (T) => T ): Array[T]

किसी सरणी को किसी फ़ंक्शन के बार-बार शुरू होने वाले एप्लिकेशन पर लौटाता है।

9

def ofDim[T]( n1: Int ): Array[T]

दिए गए आयामों के साथ सरणी बनाता है।

10

def ofDim[T]( n1: Int, n2: Int ): Array[Array[T]]

एक 2-आयामी सरणी बनाता है

1 1

def ofDim[T]( n1: Int, n2: Int, n3: Int ): Array[Array[Array[T]]]

एक 3-आयामी सरणी बनाता है

12

def range( start: Int, end: Int, step: Int ): Array[Int]

एक सरणी देता है जिसमें कुछ पूर्णांक अंतराल में समान रूप से दूरी वाले मान होते हैं।

13

def range( start: Int, end: Int ): Array[Int]

किसी सरणी को किसी श्रेणी में बढ़ते पूर्णांक के अनुक्रम में देता है।

14

def tabulate[T]( n: Int )(f: (Int)=> T): Array[T]

एक सरणी देता है जिसमें 0 से शुरू होने वाले पूर्णांक मानों की श्रेणी में दिए गए फ़ंक्शन के मान होते हैं।

15

def tabulate[T]( n1: Int, n2: Int )( f: (Int, Int ) => T): Array[Array[T]]

0 से शुरू होने वाले पूर्णांक मानों की श्रेणियों पर दिए गए फ़ंक्शन के मानों से युक्त दो-आयामी सरणी देता है।

स्काला के पास संग्रह पुस्तकालय का एक समृद्ध समूह है। संग्रह चीजों का कंटेनर है। उन कंटेनरों को अनुक्रमित किया जा सकता है, सूची, टपल, विकल्प, मानचित्र, आदि जैसी वस्तुओं के रैखिक सेट। संग्रह में तत्वों की एक मनमानी संख्या हो सकती है या शून्य या एक तत्व (जैसे, विकल्प) के लिए बाध्य हो सकती है।

संग्रह हो सकते हैं strict या lazy। आलसी संग्रह में ऐसे तत्व होते हैं जो तब तक मेमोरी का उपभोग नहीं कर सकते हैं जब तक वे एक्सेस न हों, जैसेRanges। इसके अतिरिक्त, संग्रह हो सकता हैmutable (संदर्भ की सामग्री बदल सकती है) या immutable(एक संदर्भ को संदर्भित करता है कि बात कभी नहीं बदला है)। ध्यान दें कि अपरिवर्तनीय संग्रह में उत्परिवर्तनीय आइटम हो सकते हैं।

कुछ समस्याओं के लिए, परस्पर संग्रह बेहतर काम करते हैं, और दूसरों के लिए, अपरिवर्तनीय संग्रह बेहतर काम करते हैं। जब संदेह होता है, तो एक अपरिवर्तनीय संग्रह के साथ शुरू करना और बाद में इसे बदलना बेहतर होता है, यदि आपको परस्पर योग्य लोगों की आवश्यकता होती है।

यह अध्याय सबसे अधिक उपयोग किए जाने वाले संग्रह प्रकारों पर प्रकाश फेंकता है और उन संग्रहों पर सबसे अधिक बार उपयोग किए जाने वाले संचालन।

अनु क्रमांक विवरण के साथ संग्रह
1

Scala Lists

स्काला की सूची [T] टाइप T की एक लिंक की गई सूची है।

2

Scala Sets

एक सेट एक ही प्रकार के जोड़ीदार विभिन्न तत्वों का एक संग्रह है।

3

Scala Maps

एक मानचित्र कुंजी / मूल्य जोड़े का एक संग्रह है। किसी भी मूल्य को उसकी कुंजी के आधार पर प्राप्त किया जा सकता है।

4

Scala Tuples

एक सरणी या सूची के विपरीत, एक ट्यूल अलग-अलग प्रकार की वस्तुओं को पकड़ सकता है।

5

Scala Options

विकल्प [टी] किसी दिए गए प्रकार के शून्य या एक तत्व के लिए एक कंटेनर प्रदान करता है।

6

Scala Iterators

एक पुनरावृत्ति एक संग्रह नहीं है, बल्कि संग्रह के तत्वों को एक-एक करके एक्सेस करने का तरीका है।

एक विशेषता विधि और क्षेत्र परिभाषाओं को कूटबद्ध करती है, जिसे बाद में कक्षाओं में मिलाकर पुन: उपयोग किया जा सकता है। वर्ग की विरासत के विपरीत, जिसमें प्रत्येक वर्ग को केवल एक सुपरक्लास से विरासत में प्राप्त होना चाहिए, एक वर्ग किसी भी संख्या में लक्षणों में मिश्रण कर सकता है।

समर्थित विधियों के हस्ताक्षर को निर्दिष्ट करके ऑब्जेक्ट प्रकार को परिभाषित करने के लिए लक्षण का उपयोग किया जाता है। स्कैला भी लक्षण को आंशिक रूप से कार्यान्वित करने की अनुमति देता है लेकिन लक्षण में निर्माण पैरामीटर नहीं हो सकता है।

एक विशेषता परिभाषा एक वर्ग परिभाषा की तरह ही दिखाई देती है, सिवाय इसके कि वह कीवर्ड का उपयोग करती है trait। निम्नलिखित विशेषता का मूल उदाहरण वाक्यविन्यास है।

वाक्य - विन्यास

trait Equal {
   def isEqual(x: Any): Boolean
   def isNotEqual(x: Any): Boolean = !isEqual(x)
}

इस विशेषता के दो तरीके हैं isEqual तथा isNotEqual। यहां, हमने इस्क्वायल के लिए कोई कार्यान्वयन नहीं दिया है जहां एक और विधि का कार्यान्वयन है। एक विशेषता का विस्तार करने वाले बाल वर्ग संयुक्त राष्ट्र के कार्यान्वित तरीकों के लिए कार्यान्वयन दे सकते हैं। इसलिए एक लक्षण हमारे पास बहुत कुछ हैabstract classes जावा में।

आइए हम लक्षण का एक उदाहरण मानते हैं Equal दो तरीके हैं isEqual() तथा isNotEqual()। लक्षणEqual एक लागू पद्धति है जो है isEqual() इसलिए जब उपयोगकर्ता परिभाषित वर्ग Point लक्षण का विस्तार करता है Equal, पर लागू होता है isEqual() में विधि Point कक्षा प्रदान की जानी चाहिए।

यहां स्काला की दो महत्वपूर्ण विधि को जानना आवश्यक है, जिनका उपयोग निम्नलिखित उदाहरण में किया जाता है।

  • obj.isInstanceOf [Point] जाँच करने के लिए ओबज और प्वाइंट के प्रकार समान नहीं हैं।

  • obj.asInstanceOf [Point] ऑब्जेक्ट ऑब्जेक्टिव टाइप करके सटीक कास्टिंग का मतलब है और प्वाइंट टाइप के समान ओब्जेक्ट लौटाता है।

लक्षणों को लागू करने के लिए निम्नलिखित उदाहरण कार्यक्रम का प्रयास करें।

उदाहरण

trait Equal {
   def isEqual(x: Any): Boolean
   def isNotEqual(x: Any): Boolean = !isEqual(x)
}

class Point(xc: Int, yc: Int) extends Equal {
   var x: Int = xc
   var y: Int = yc
   
   def isEqual(obj: Any) = obj.isInstanceOf[Point] && obj.asInstanceOf[Point].x == y
}

object Demo {
   def main(args: Array[String]) {
      val p1 = new Point(2, 3)
      val p2 = new Point(2, 4)
      val p3 = new Point(3, 3)

      println(p1.isNotEqual(p2))
      println(p1.isNotEqual(p3))
      println(p1.isNotEqual(2))
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

true
false
true

मूल्य वर्ग और यूनिवर्सल लक्षण

रनटाइम ऑब्जेक्ट्स को आवंटित करने से बचने के लिए स्काला में मूल्य वर्ग नए तंत्र हैं। इसमें ठीक एक के साथ एक प्राथमिक निर्माता होता हैvalपैरामीटर। इसमें केवल विधियाँ (डीईएफ) की अनुमति नहीं है जो कि var, val, nested classes, traits, या ऑब्जेक्ट्स हैं। मान वर्ग को किसी अन्य वर्ग द्वारा विस्तारित नहीं किया जा सकता है। AnyVal के साथ अपने मूल्य वर्ग का विस्तार करके यह संभव हो सकता है। कस्टम डेटाटाइप्स की रनटाइम ओवरहेड के बिना।

आइए हम मूल्य वर्गों का एक उदाहरण लेते हैं वजन, ऊंचाई, ईमेल, आयु, आदि। इन सभी उदाहरणों के लिए आवेदन में मेमोरी आवंटित करना आवश्यक नहीं है।

एक मान वर्ग को लक्षणों का विस्तार करने की अनुमति नहीं है। गुण का विस्तार करने के लिए मूल्य वर्गों को अनुमति देने के लिए,universal traits पेश किए जाते हैं, जिसके लिए विस्तार किया जाता है Any

उदाहरण

trait Printable extends Any {
   def print(): Unit = println(this)
}
class Wrapper(val underlying: Int) extends AnyVal with Printable

object Demo {
   def main(args: Array[String]) {
      val w = new Wrapper(3)
      w.print() // actually requires instantiating a Wrapper instance
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

यह आपको Wrapper क्लास का हैश कोड देगा।

Wrapper@13

कब उपयोग करें लक्षण?

कोई ठोस नियम नहीं है, लेकिन यहां कुछ दिशानिर्देशों पर विचार किया गया है -

  • यदि व्यवहार का पुन: उपयोग नहीं किया जाएगा, तो इसे एक ठोस वर्ग बनाएं। यह सब के बाद पुन: प्रयोज्य व्यवहार नहीं है।

  • यदि इसे कई, असंबद्ध वर्गों में पुन: उपयोग किया जा सकता है, तो इसे एक विशेषता बनाएं। केवल लक्षणों को वर्ग पदानुक्रम के विभिन्न भागों में मिलाया जा सकता है।

  • यदि आप चाहते हैं inherit जावा कोड में, एक अमूर्त वर्ग का उपयोग करें।

  • यदि आप इसे संकलित रूप में वितरित करने की योजना बनाते हैं, और आप बाहरी समूहों से अपेक्षा करते हैं कि वे इससे प्राप्त होने वाली कक्षाओं को लिखें, तो आप एक अमूर्त वर्ग का उपयोग करने की ओर झुक सकते हैं।

  • यदि दक्षता बहुत महत्वपूर्ण है, तो कक्षा का उपयोग करने की ओर झुकें।

फंक्शन वैल्यू और क्लोजर के बाद, पैटर्न मिलान स्कैला का दूसरा सबसे व्यापक रूप से इस्तेमाल किया जाने वाला फीचर है। संदेशों को संसाधित करने में स्काला पैटर्न मिलान के लिए बहुत सहायता प्रदान करता है।

एक पैटर्न मैच में विकल्प का एक क्रम शामिल होता है, प्रत्येक कीवर्ड के साथ शुरू होता है case। प्रत्येक विकल्प में एक शामिल हैpattern और एक या अधिक expressions, जिसका मूल्यांकन यदि पैटर्न से मेल खाता है। एक तीर का प्रतीक => पैटर्न को भावों से अलग करता है।

निम्नलिखित उदाहरण कार्यक्रम का प्रयास करें, जो दिखाता है कि पूर्णांक मूल्य के खिलाफ कैसे मिलान किया जाए।

उदाहरण

object Demo {
   def main(args: Array[String]) {
      println(matchTest(3))
   }
   
   def matchTest(x: Int): String = x match {
      case 1 => "one"
      case 2 => "two"
      case _ => "many"
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

many

केस स्टेटमेंट वाला ब्लॉक एक फ़ंक्शन को परिभाषित करता है, जो पूर्णांक को स्ट्रिंग्स में मैप करता है। मैच कीवर्ड किसी ऑब्जेक्ट में फ़ंक्शन (पैटर्न मिलान फ़ंक्शन ऊपर की तरह) लागू करने का एक सुविधाजनक तरीका प्रदान करता है।

निम्नलिखित उदाहरण कार्यक्रम का प्रयास करें, जो विभिन्न प्रकारों के पैटर्न के खिलाफ एक मूल्य से मेल खाता है।

उदाहरण

object Demo {
   def main(args: Array[String]) {
      println(matchTest("two"))
      println(matchTest("test"))
      println(matchTest(1))
   }
   
   def matchTest(x: Any): Any = x match {
      case 1 => "one"
      case "two" => 2
      case y: Int => "scala.Int"
      case _ => "many"
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

2
many
one

केस क्लासेस का उपयोग करके मिलान करना

case classesविशेष वर्ग हैं जो पैटर्न में केस एक्सप्रेशन के साथ उपयोग किए जाते हैं। सिंथेटिक रूप से, ये एक विशेष संशोधक के साथ मानक कक्षाएं हैं:case

निम्नलिखित का प्रयास करें, यह केस क्लास का उपयोग करके एक साधारण पैटर्न से मेल खाता उदाहरण है।

उदाहरण

object Demo {
   def main(args: Array[String]) {
      val alice = new Person("Alice", 25)
      val bob = new Person("Bob", 32)
      val charlie = new Person("Charlie", 32)
   
      for (person <- List(alice, bob, charlie)) {
         person match {
            case Person("Alice", 25) => println("Hi Alice!")
            case Person("Bob", 32) => println("Hi Bob!")
            case Person(name, age) => println(
               "Age: " + age + " year, name: " + name + "?")
         }
      }
   }
   case class Person(name: String, age: Int)
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

Hi Alice!
Hi Bob!
Age: 32 year, name: Charlie?

केस कीवर्ड जोड़ने से कंपाइलर कई उपयोगी सुविधाओं को स्वचालित रूप से जोड़ देता है। कीवर्ड पैटर्न मिलान में केस एक्सप्रेशंस के साथ जुड़ाव का सुझाव देता है।

सबसे पहले, कंपाइलर कंस्ट्रक्टर के तर्कों को स्वचालित रूप से अपरिवर्तनीय फ़ील्ड (वैल) में परिवर्तित करता है। वैल कीवर्ड वैकल्पिक है। यदि आप परिवर्तनशील फ़ील्ड चाहते हैं, तो var कीवर्ड का उपयोग करें। इसलिए, हमारी कंस्ट्रक्टर तर्क सूची अब छोटी हो गई है।

दूसरा, संकलक स्वचालित रूप से लागू होता है equals, hashCode, तथा toStringकक्षा के लिए तरीके, जो निर्माता तर्क के रूप में निर्दिष्ट फ़ील्ड का उपयोग करते हैं। इसलिए, अब हमें अपने स्वयं के (स्ट्रिंग) तरीकों की आवश्यकता नहीं है।

अंत में, भी, का शरीर Person वर्ग खाली हो जाता है क्योंकि ऐसी कोई विधियाँ नहीं हैं जिन्हें हमें परिभाषित करने की आवश्यकता है!

यह अध्याय बताता है कि स्काला किस तरह से नियमित अभिव्यक्ति का समर्थन करती है Regex scala.util.matching पैकेज में उपलब्ध वर्ग।

निम्नलिखित उदाहरण कार्यक्रम का प्रयास करें जहां हम शब्द खोजने की कोशिश करेंगे Scala एक बयान से।

उदाहरण

import scala.util.matching.Regex

object Demo {
   def main(args: Array[String]) {
      val pattern = "Scala".r
      val str = "Scala is Scalable and cool"
      
      println(pattern findFirstIn str)
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

Some(Scala)

हम एक स्ट्रिंग बनाते हैं और कॉल करते हैं r( )इस पर विधि। स्काला ने स्पष्ट रूप से स्ट्रिंग को एक रिचस्ट्रिंग में परिवर्तित किया और रेगेक्स का एक उदाहरण प्राप्त करने के लिए उस विधि को आमंत्रित किया। नियमित अभिव्यक्ति का पहला मैच खोजने के लिए, बस कॉल करेंfindFirstIn()तरीका। यदि केवल पहली घटना को खोजने के बजाय हम मिलान शब्द की सभी घटनाओं को खोजना चाहते हैं, तो हम इसका उपयोग कर सकते हैंfindAllIn( ) विधि और यदि लक्ष्य स्ट्रिंग में कई स्काला शब्द उपलब्ध हैं, तो यह सभी मिलान शब्दों का एक संग्रह लौटाएगा।

आप परिणामी सूची को संक्षिप्त करने के लिए mkString () पद्धति का उपयोग कर सकते हैं और स्कैला के छोटे और पूंजीगत मामले को खोजने के लिए एक पाइप (!) का उपयोग कर सकते हैं और आप उपयोग कर सकते हैं। Regex इसके बजाय निर्माता या r() एक पैटर्न बनाने की विधि।

निम्नलिखित उदाहरण कार्यक्रम का प्रयास करें।

उदाहरण

import scala.util.matching.Regex

object Demo {
   def main(args: Array[String]) {
      val pattern = new Regex("(S|s)cala")
      val str = "Scala is scalable and cool"
      
      println((pattern findAllIn str).mkString(","))
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

Scala,scala

यदि आप मिलान पाठ को बदलना चाहते हैं, तो हम उपयोग कर सकते हैं replaceFirstIn( ) पहले मैच को बदलने के लिए या replaceAllIn( ) सभी घटनाओं को बदलने के लिए।

उदाहरण

object Demo {
   def main(args: Array[String]) {
      val pattern = "(S|s)cala".r
      val str = "Scala is scalable and cool"
      
      println(pattern replaceFirstIn(str, "Java"))
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

Java is scalable and cool

नियमित अभिव्यक्तियाँ बनाना

स्काला जावा से अपनी नियमित अभिव्यक्ति सिंटैक्स प्राप्त करता है, जो बदले में पर्ल की अधिकांश विशेषताओं को विरासत में देता है। यहाँ कुछ उदाहरण दिए गए हैं जो रिफ्रेशर के रूप में पर्याप्त होने चाहिए -

निम्नलिखित जावा में उपलब्ध सभी नियमित अभिव्यक्ति मेटा चरित्र सिंटैक्स की सूची नीचे दी गई है।

उपसूचक माचिस
^ लाइन की शुरुआत से मेल खाता है।
$ लाइन के अंत मेल खाता है।
न्यूलाइन को छोड़कर किसी भी एकल वर्ण से मेल खाता है। M विकल्प का उपयोग करने से यह न्यूलाइन को भी मैच कर सकता है।
[...] कोष्ठक में किसी एक वर्ण से मेल खाता है।
[^ ...] किसी भी एकल वर्ण को कोष्ठक में नहीं मिलाता है
\\ए पूरे स्ट्रिंग की शुरुआत
\\ z पूरी स्ट्रिंग का अंत
\\ जेड स्वीकार्य अंतिम पंक्ति टर्मिनेटर को छोड़कर पूरे स्ट्रिंग का अंत।
फिर * पूर्ववर्ती अभिव्यक्ति के 0 या अधिक घटनाओं से मेल खाता है।
फिर + पिछली चीज़ के 1 या अधिक से मेल खाता है
फिर? पूर्ववर्ती अभिव्यक्ति की 0 या 1 घटना से मेल खाता है।
पुनः {n} पूर्ववर्ती अभिव्यक्ति की घटनाओं की बिल्कुल n संख्या से मेल खाता है।
पुनः {n,} पूर्ववर्ती अभिव्यक्ति की n या अधिक घटनाओं से मेल खाता है।
पुनः {n, m} कम से कम n और पूर्ववर्ती अभिव्यक्ति के अधिकांश m घटनाओं पर मेल खाता है।
a | b माचिस या तो एक या बी।
(फिर से) समूह नियमित अभिव्यक्ति और याद किए गए पाठ से मेल खाते हैं।
(?: re) मिलान किए गए पाठ को याद किए बिना समूह नियमित अभिव्यक्ति।
(?> re) बैकट्रैकिंग के बिना स्वतंत्र पैटर्न से मेल खाता है।
\\ w शब्द वर्णों से मेल खाता है।
\\ डब्ल्यू नॉनवर्ड कैरेक्टर से मेल खाता है।
\\ s व्हॉट्सएप से मेल खाता है। [\ T \ n \ r \ f] के बराबर है।
\\ एस मैच नॉनवॉइटस्पेस।
\\ d अंकों का मिलान करता है। [0-9] के बराबर है।
\\ डी Nondigits से मेल खाता है।
\\ए स्ट्रिंग की शुरुआत से मेल खाता है।
\\ जेड स्ट्रिंग का अंत मेल खाता है। यदि कोई नई रेखा मौजूद है, तो यह नई रेखा से ठीक पहले मेल खाती है।
\\ z स्ट्रिंग का अंत मेल खाता है।
\\ जी मैच प्वाइंट जहां अंतिम मैच समाप्त हुआ।
\\ n समूह संख्या "n" पर कब्जा करने के लिए बैक-रेफरेंस
\\ ख शब्द सीमाएँ मेल खाती हैं जब बाहर कोष्ठक। कोष्ठक के अंदर होने पर बैकस्पेस (0x08) से मेल खाता है।
\\ बी गैर-सीमा सीमाओं से मेल खाता है।
\\ n, \\ t, आदि। मेल खाता है नई गाड़ी, गाड़ी का रिटर्न, टैब आदि।
\\ क्यू एस्केप (बोली) सभी वर्णों को \\ E तक
\\इ एंड्स उद्धरण की शुरुआत \\ Q से हुई

नियमित अभिव्यक्ति के उदाहरण

उदाहरण विवरण
न्यूलाइन को छोड़कर किसी भी वर्ण से मेल करें
[आर आर] uby मैच "रूबी" या "रूबी"
रगड़ [तु] मैच "माणिक" या "रुबे"
[AEIOU] किसी भी लोअरकेस स्वर का मिलान करें
[0-9] किसी अंक का मिलान करें; समान [0123456789]
[Az] किसी भी लोअरकेस ASCII पत्र का मिलान करें
[AZ] किसी भी अपरकेस ASCII पत्र से मिलान करें
[एक-zA-Z0-9] उपरोक्त में से कोई भी मिलान करें
[^ AEIOU] लोअरकेस स्वर के अलावा किसी भी चीज़ का मिलान करें
[^ 0-9] एक अंक के अलावा कुछ भी मिलान करें
\\ d एक अंक का मिलान करें: [0-9]
\\ डी एक nondigit मैच: [^ 0-9]
\\ s एक व्हाट्सएप पात्र से मिलान करें: [\ t \ r \ n \ f]
\\ एस मैच नॉनवॉइटस्पेस: [^ \ t \ r \ n \ f]
\\ w एक एकल शब्द चरित्र से मेल खाएँ: [A-Za-z0-9_]
\\ डब्ल्यू एक चरित्र का मिलान करें: [^ A-Za-z0-9_]
माणिक? मैच "रगड़" या "रूबी": y वैकल्पिक है
माणिक* मैच "रगड़" प्लस 0 या अधिक ys
माणिक + मैच "रगड़" प्लस 1 या अधिक वाईएस
\\ d {3} बिल्कुल 3 अंको का मिलान करें
\\ d {3,} 3 या अधिक अंकों का मिलान करें
\\ d {3,5} मैच 3, 4, या 5 अंक
\\ डी \\ d + कोई समूह नहीं: + दोहराता है \\ d
(\\ डी \\ घ) + / समूहीकृत: + दोहराता \\ डी \ डी जोड़ी
([आरआर] uby (,)?) + मैच "रूबी", "रूबी, रूबी, रूबी", आदि।

Note- कि प्रत्येक बैकस्लैश ऊपर स्ट्रिंग में दो बार दिखाई देता है। इसका कारण यह है कि जावा और स्काला में एक एकल बैकस्लैश एक स्ट्रिंग अक्षर में एक भागने वाला चरित्र है, न कि एक नियमित चरित्र जो स्ट्रिंग में दिखाई देता है। इसलिए '\' के बजाय, आपको स्ट्रिंग में एकल बैकस्लैश प्राप्त करने के लिए '\\' लिखना होगा।

निम्नलिखित उदाहरण कार्यक्रम का प्रयास करें।

उदाहरण

import scala.util.matching.Regex

object Demo {
   def main(args: Array[String]) {
      val pattern = new Regex("abl[ae]\\d+")
      val str = "ablaw is able1 and cool"
      
      println((pattern findAllIn str).mkString(","))
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

able1

स्काला के अपवाद जावा की तरह कई अन्य भाषाओं में अपवादों की तरह काम करते हैं। सामान्य तरीके से एक मूल्य वापस करने के बजाय, एक विधि अपवाद को फेंककर समाप्त कर सकती है। हालाँकि, स्काला ने वास्तव में अपवादों की जाँच नहीं की है।

जब आप अपवादों को संभालना चाहते हैं, तो आप एक कोशिश {...} पकड़ {...} का उपयोग करते हैं जैसे आप जावा में करते हैं सिवाय इसके कि अपवाद को पहचानने और संभालने के लिए पकड़ ब्लॉक मिलान का उपयोग करता है।

अपवाद फेंकना

एक अपवाद को फेंकना जावा में जैसा दिखता है। आप एक अपवाद ऑब्जेक्ट बनाते हैं और फिर आप इसे इसके साथ फेंक देते हैंthrow कीवर्ड निम्नानुसार है।

throw new IllegalArgumentException

पकड़ने के अपवाद

स्काला आपको अनुमति देता है try/catch किसी एकल ब्लॉक में कोई अपवाद नहीं है और फिर इसका उपयोग करके इसके खिलाफ पैटर्न मिलान करें caseब्लॉक। अपवाद को संभालने के लिए निम्न उदाहरण कार्यक्रम का प्रयास करें।

उदाहरण

import java.io.FileReader
import java.io.FileNotFoundException
import java.io.IOException

object Demo {
   def main(args: Array[String]) {
      try {
         val f = new FileReader("input.txt")
      } catch {
         case ex: FileNotFoundException =>{
            println("Missing file exception")
         }
         
         case ex: IOException => {
            println("IO Exception")
         }
      }
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

Missing file exception

इस का व्यवहार try-catchअपवाद के साथ अन्य भाषाओं में अभिव्यक्ति समान है। शरीर निष्पादित होता है, और यदि यह एक अपवाद फेंकता है, तो प्रत्येकcatch क्लॉज को बदले में देने की कोशिश की जाती है।

अंत में क्लॉज

आप एक के साथ एक अभिव्यक्ति लपेट सकते हैं finallyयदि आप अभिव्यक्ति को समाप्त करने के लिए कोई कोड निष्पादित करना चाहते हैं, तो खंड को रोकें। निम्नलिखित कार्यक्रम का प्रयास करें।

उदाहरण

import java.io.FileReader
import java.io.FileNotFoundException
import java.io.IOException

object Demo {
   def main(args: Array[String]) {
      try {
         val f = new FileReader("input.txt")
      } catch {
         case ex: FileNotFoundException => {
            println("Missing file exception")
         }
         
         case ex: IOException => {
            println("IO Exception")
         }
      } finally {
         println("Exiting finally...")
      }
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

Missing file exception
Exiting finally...

स्काला में एक एक्सट्रैक्टर एक ऑब्जेक्ट है जिसमें एक विधि है जिसे कहा जाता है unapplyइसके सदस्यों में से एक के रूप में। उस अनपेक्षित विधि का उद्देश्य एक मूल्य से मेल खाना और इसे अलग करना है। अक्सर, एक्सट्रैक्टर ऑब्जेक्ट एक दोहरी विधि को भी परिभाषित करता हैapply मूल्यों के निर्माण के लिए, लेकिन इसकी आवश्यकता नहीं है।

उदाहरण

आइए हम एक उदाहरण लेते हैं जो दोनों को परिभाषित करता है apply तथा unapplyतरीकों। लागू पद्धति का हमेशा की तरह एक ही अर्थ होता है: यह परीक्षण को एक ऐसी वस्तु में बदल देता है, जिसे कोष्ठक में तर्क के लिए लागू किया जा सकता है उसी तरह से एक विधि को लागू किया जाता है। तो आप स्ट्रिंग "[email protected]" का निर्माण करने के लिए टेस्ट ("ज़ारा", "gmail.com") लिख सकते हैं।

unapply विधि वह है जो टेस्ट क्लास को एक में बदल देती है extractor और यह निर्माण प्रक्रिया को उलट देता है apply। जहां आवेदन दो तार लेता है और उनमें से एक ईमेल पता स्ट्रिंग बनाता है, अनपेक्षित रूप से एक ईमेल पता लेता है और संभावित रूप से दो तार देता है:user और यह domain पते की।

unapplyउस मामले को भी संभालना चाहिए जहां दिए गए स्ट्रिंग एक ईमेल पता नहीं है। यही कारण है कि अनुचित रूप से तारों के जोड़े पर एक विकल्प-प्रकार लौटाता है। इसका परिणाम या तो हैSome (user, domain)यदि स्ट्रिंग स्ट्रिंग दिए गए उपयोगकर्ता और डोमेन भागों के साथ एक ईमेल पता है, या कोई नहीं, अगर str एक ईमेल पता नहीं है। यहाँ कुछ उदाहरण इस प्रकार हैं।

वाक्य - विन्यास

unapply("[email protected]") equals Some("Zara", "gmail.com")
unapply("Zara Ali") equals None

उदाहरण के बाद कार्यक्रम ईमेल पते के लिए एक चिमटा वस्तु दिखाता है।

उदाहरण

object Demo {
   def main(args: Array[String]) {
      println ("Apply method : " + apply("Zara", "gmail.com"));
      println ("Unapply method : " + unapply("[email protected]"));
      println ("Unapply method : " + unapply("Zara Ali"));
   }
   
   // The injection method (optional)
   def apply(user: String, domain: String) = {
      user +"@"+ domain
   }

   // The extraction method (mandatory)
   def unapply(str: String): Option[(String, String)] = {
      val parts = str split "@"
      
      if (parts.length == 2){
         Some(parts(0), parts(1)) 
      } else {
         None
      }
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

Apply method : [email protected]
Unapply method : Some((Zara,gmail.com))
Unapply method : None

चिमटा के साथ मिलान पैटर्न

जब कक्षा का उदाहरण शून्य या अधिक मापदंडों की सूची के साथ कोष्ठक द्वारा पीछा किया जाता है, तो संकलक को आमंत्रित करता है applyउस उदाहरण पर विधि। हम वस्तुओं और कक्षाओं में दोनों को लागू कर सकते हैं।

जैसा कि ऊपर बताया गया है, का उद्देश्य unapplyविधि वह विशिष्ट मूल्य निकालना है जिसकी हम तलाश कर रहे हैं। यह विपरीत ऑपरेशन करता हैapplyकर देता है। जब एक चिमटा वस्तु की तुलना का उपयोग करmatch बयान unapply विधि स्वचालित रूप से निष्पादित की जाएगी।

निम्नलिखित उदाहरण कार्यक्रम का प्रयास करें।

उदाहरण

object Demo {
   def main(args: Array[String]) {
      val x = Demo(5)
      println(x)

      x match {
         case Demo(num) => println(x+" is bigger two times than "+num)
         
         //unapply is invoked
         case _ => println("i cannot calculate")
      }
   }
   def apply(x: Int) = x*2
   def unapply(z: Int): Option[Int] = if (z%2==0) Some(z/2) else None
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

10
10 is bigger two times than 5

Scala किसी भी Java ऑब्जेक्ट का उपयोग करने के लिए खुला है और java.io.File उन वस्तुओं में से एक है जिनका उपयोग स्काला प्रोग्रामिंग में फ़ाइलों को पढ़ने और लिखने के लिए किया जा सकता है।

निम्नलिखित एक फ़ाइल में लिखने के लिए एक उदाहरण कार्यक्रम है।

उदाहरण

import java.io._

object Demo {
   def main(args: Array[String]) {
      val writer = new PrintWriter(new File("test.txt" ))

      writer.write("Hello Scala")
      writer.close()
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

यह एक फाइल बनायेगा जिसका नाम है Demo.txtवर्तमान निर्देशिका में, जहां कार्यक्रम रखा गया है। निम्नलिखित उस फ़ाइल की सामग्री है।

उत्पादन

Hello Scala

कमांड लाइन से एक लाइन पढ़ना

कभी-कभी आपको स्क्रीन से उपयोगकर्ता इनपुट पढ़ने की आवश्यकता होती है और फिर कुछ आगे की प्रक्रिया के लिए आगे बढ़ते हैं। निम्न उदाहरण कार्यक्रम आपको दिखाता है कि कमांड लाइन से इनपुट कैसे पढ़ें।

उदाहरण

object Demo {
   def main(args: Array[String]) {
      print("Please enter your input : " )
      val line = Console.readLine
      
      println("Thanks, you just typed: " + line)
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

Please enter your input : Scala is great
Thanks, you just typed: Scala is great

फ़ाइल सामग्री पढ़ना

फाइलों से पढ़ना वास्तव में सरल है। आप स्काला का उपयोग कर सकते हैंSourceफ़ाइलों को पढ़ने के लिए क्लास और उसके साथी ऑब्जेक्ट। निम्नलिखित उदाहरण है जो आपको दिखाता है कि किस तरह से पढ़ना है"Demo.txt" फ़ाइल जो हमने पहले बनाई थी।

उदाहरण

import scala.io.Source

object Demo {
   def main(args: Array[String]) {
      println("Following is the content read:" )

      Source.fromFile("Demo.txt" ).foreach { 
         print 
      }
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

Following is the content read:
Hello Scala