कोटलिन - नियंत्रण प्रवाह

पिछले अध्याय में हमने कोटलिन प्रणाली में उपलब्ध विभिन्न प्रकार के डेटा प्रकारों के बारे में सीखा है। इस अध्याय में, हम कोटलिन में उपलब्ध विभिन्न प्रकार के नियंत्रण प्रवाह तंत्र पर चर्चा करेंगे।

यदि नहीं तो

कोटलिन एक कार्यात्मक भाषा है इसलिए कोटलिन में हर कार्यात्मक भाषा की तरह “if”एक अभिव्यक्ति है, यह एक कीवर्ड नहीं है। भाव“if”जब भी आवश्यक हो एक मूल्य लौटाएगा। अन्य प्रोग्रामिंग भाषा की तरह,“if-else”ब्लॉक का उपयोग प्रारंभिक सशर्त जाँच ऑपरेटर के रूप में किया जाता है। निम्नलिखित उदाहरण में, हम दो चर की तुलना करेंगे और तदनुसार आवश्यक आउटपुट प्रदान करेंगे।

fun main(args: Array<String>) {
   val a:Int = 5
   val b:Int = 2
   var max: Int
   
   if (a > b) {
      max = a
   } else {
      max = b
   }
   print("Maximum of a or b is " +max)
 
   // As expression 
   // val max = if (a > b) a else b
}

कोड का उपरोक्त टुकड़ा ब्राउज़र में परिणामस्वरूप निम्न आउटपुट देता है। हमारे उदाहरण में कोड की एक और पंक्ति भी शामिल है, जिसमें दर्शाया गया है कि कैसे उपयोग किया जाए“If” एक अभिव्यक्ति के रूप में बयान।

Maximum of a or b is 5

कब का उपयोग

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

fun main(args: Array<String>) {
   val x:Int = 5
   when (x) {
      1 -> print("x = = 1")
      2 -> print("x = = 2")
      
      else -> { // Note the block
         print("x is neither 1 nor 2")
      }
   }
}

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देता है।

x is neither 1 nor 2

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

fun main(args: Array<String>) {
   val x:Int = 5
   when (x) {
      1,2 -> print(" Value of X either 1,2")
      
      else -> { // Note the block
         print("x is neither 1 nor 2")
      }
   }
}

ब्राउज़र में समान चलाएं, जो ब्राउज़र में निम्न आउटपुट देगा।

x is neither 1 nor 2

पाश के लिए

लूप एक ऐसा आविष्कार है जो किसी भी प्रकार की डेटा संरचना के माध्यम से पुनरावृति को लचीलापन प्रदान करता है। अन्य प्रोग्रामिंग भाषाओं की तरह, कोटलिन भी कई प्रकार की लूपिंग पद्धति प्रदान करता है, हालांकि, उनमें से“For”सबसे सफल है। फोर लूप का कार्यान्वयन और उपयोग वैचारिक रूप से लूप के लिए जावा के समान है। निम्नलिखित उदाहरण से पता चलता है कि हम वास्तविक जीवन के उदाहरणों में कैसे उपयोग कर सकते हैं।

fun main(args: Array<String>) {
   val items = listOf(1, 2, 3, 4)
   for (i in items) println("values of the array"+i)
}

उपरोक्त कोड में, हमने "आइटम" के रूप में नामित एक सूची घोषित की है और लूप के लिए हम उस परिभाषित सूची के माध्यम से पुनरावृत्ति कर रहे हैं और ब्राउज़र में इसके मूल्य को प्रिंट कर रहे हैं। निम्नलिखित आउटपुट है।

values of the array1
values of the array2
values of the array3
values of the array4

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

fun main(args: Array<String>) {
   val items = listOf(1, 22, 83, 4)
   
   for ((index, value) in items.withIndex()) {
      println("the element at $index is $value")
   }
}

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

the element at 0 is 1
the element at 1 is 22
the element at 2 is 83
the element at 3 is 4

जबकि लूप और डू-जबकि लूप

जबकि और दो-जबकि बिल्कुल उसी तरह से काम करते हैं जैसे वे अन्य प्रोग्रामिंग भाषाओं में करते हैं। इन दो छोरों के बीच एकमात्र अंतर यह है कि डू-लूप के मामले में लूप के अंत में स्थिति का परीक्षण किया जाएगा। निम्न उदाहरण के उपयोग को दर्शाता हैWhile loop

fun main(args: Array<String>) {
   var x:Int = 0
   println("Example of While Loop--")
   
   while(x< = 10) {
      println(x)
      x++
   } 
}

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देता है।

Example of While Loop--
0
1
2
3
4
5
6
7
8
9
10

कोटलिन के पास डू-लूप नामक एक और लूप है, जहां लूप बॉडी को एक बार निष्पादित किया जाएगा, उसके बाद ही स्थिति की जांच की जाएगी। निम्न उदाहरण के उपयोग को दर्शाता हैDo-while loop

fun main(args: Array<String>) {
   var x:Int = 0
   do {
      x = x + 10
      println("I am inside Do block---"+x)
   } while(x <= 50)
}

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देता है। उपरोक्त कोड में, कोटलिन कंपाइलर डीओ ब्लॉक को निष्पादित करेगा, फिर यह ब्लॉक में स्थित स्थिति की जाँच के लिए जाएगा।

I am inside Do block---10
I am inside Do block---20
I am inside Do block---30
I am inside Do block---40
I am inside Do block---50
I am inside Do block---60

रिटर्न, ब्रेक, कंटीन्यू का उपयोग

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

Return- रिटर्न एक कीवर्ड है जो कॉलिंग फ़ंक्शन से कुछ मान को रिटर्न फ़ंक्शन से लौटाता है। निम्नलिखित उदाहरण में, हम अपने कोटलिन कोडिंग ग्राउंड का उपयोग करके इस परिदृश्य को लागू करेंगे।

fun main(args: Array<String>) {
   var x:Int = 10
   println("The value of X is--"+doubleMe(x))
}
fun doubleMe(x:Int):Int {
   return 2*x;
}

कोड के उपरोक्त भाग में, हम एक अन्य फ़ंक्शन को कॉल कर रहे हैं और इनपुट को 2 से गुणा कर रहे हैं, और परिणामी मान को उस फ़ंक्शन पर लौटाते हैं जो हमारा मुख्य कार्य है। कोटलिन फ़ंक्शन को एक अलग तरीके से परिभाषित करता है जिसे हम बाद के अध्याय में देखेंगे। अभी के लिए, यह समझना पर्याप्त है कि उपरोक्त कोड ब्राउज़र में निम्न आउटपुट उत्पन्न करेगा।

The value of X is--20

Continue & Break- जारी रखना और तोड़ना एक तार्किक समस्या का सबसे महत्वपूर्ण हिस्सा है। "ब्रेक" कीवर्ड नियंत्रक प्रवाह को समाप्त कर देता है यदि कुछ स्थिति विफल हो गई है और "जारी" इसके विपरीत करता है। यह सभी ऑपरेशन तत्काल दृश्यता के साथ होता है। कोटलिन अन्य प्रोग्रामिंग भाषाओं की तुलना में अधिक स्मार्ट है, जिसमें डेवलपर दृश्यता के रूप में एक से अधिक लेबल लगा सकता है। कोड का निम्नलिखित टुकड़ा दिखाता है कि हम कोटलिन में इस लेबल को कैसे लागू कर रहे हैं।

fun main(args: Array<String>) {
   println("Example of Break and Continue")
   myLabel@ for(x in 1..10) { // appling the custom label
      if(x = = 5) {
         println("I am inside if block with value"+x+"\n-- hence it will close the operation")
         break@myLabel //specifing the label
      } else {
         println("I am inside else block with value"+x)
         continue@myLabel
      }
   }
}

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट देता है।

Example of Break and Continue
I am inside else block with value1
I am inside else block with value2
I am inside else block with value3
I am inside else block with value4
I am inside if block with value5
-- hence it will close the operation

जैसा कि आप देख सकते हैं, नियंत्रक लूप जारी रखता है, जब तक और जब तक कि मूल्य नहीं x है 5. एक बार का मान x 5 तक पहुंचता है, अगर यह ब्लॉक को ब्लॉक करना शुरू कर देता है और एक बार ब्रेक स्टेटमेंट तक पहुंच जाता है, तो संपूर्ण नियंत्रण प्रवाह प्रोग्राम निष्पादन को समाप्त कर देता है।