गो - चर

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

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

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

byte

आमतौर पर एक एकल ओकटेट (एक बाइट)। यह एक बाइट प्रकार है।

2

int

मशीन के लिए पूर्णांक का सबसे प्राकृतिक आकार।

3

float32

एकल-सटीक फ़्लोटिंग पॉइंट मान।

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

गो में परिवर्तनीय परिभाषा

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

var variable_list optional_data_type;

यहाँ, optional_data_type एक मान्य गो डेटा प्रकार है जिसमें बाइट, इंट, फ्लोट 32, कॉम्प्लेक्स 64, बूलियन या कोई उपयोगकर्ता-परिभाषित ऑब्जेक्ट, आदि और variable_listअल्पविराम द्वारा अलग किए गए एक या अधिक पहचानकर्ता नामों से मिलकर बना हो सकता है। कुछ मान्य घोषणाएँ यहाँ दिखाई गई हैं -

var  i, j, k int;
var  c, ch byte;
var  f, salary float32;
d =  42;

बयान “var i, j, k;”घोषित करता है और चर को परिभाषित करता है i, j और k; जो संकलक को निर्देश देता है कि i, j, और k का प्रकार int नाम का चर बनाएं।

वेरिएबल्स को उनकी घोषणा में आरंभीकृत किया जा सकता है (एक प्रारंभिक मूल्य सौंपा गया है)। चर का प्रकार स्वचालित रूप से संकलक द्वारा आंका जाता है कि इसके पास दिए गए मूल्य के आधार पर। इनिशियलाइज़र में एक समरूप चिन्ह होता है, जिसके बाद एक स्थिर अभिव्यक्ति होती है -

variable_name = value;

उदाहरण के लिए,

d = 3, f = 5;    // declaration of d and f. Here d and f are int

एक इनिशलाइज़र के बिना परिभाषा के लिए: स्थिर भंडारण अवधि वाले चर को स्पष्ट रूप से निल के साथ आरंभीकृत किया जाता है (सभी बाइट्स का मान 0 होता है); अन्य सभी चर का प्रारंभिक मूल्य उनके डेटा प्रकार का शून्य मान है।

गो में स्थैतिक प्रकार की घोषणा

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

उदाहरण

निम्नलिखित उदाहरण का प्रयास करें, जहां चर को एक प्रकार के साथ घोषित किया गया है और मुख्य कार्य के अंदर शुरू किया गया है -

package main

import "fmt"

func main() {
   var x float64
   x = 20.0
   fmt.Println(x)
   fmt.Printf("x is of type %T\n", x)
}

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

20
x is of type float64

गो में डायनामिक टाइप डिक्लेरेशन / टाइप इन्वेंशन

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

उदाहरण

निम्नलिखित उदाहरण का प्रयास करें, जहां चर बिना किसी प्रकार के घोषित किए गए हैं। सूचना, प्रकार के अनुमान के मामले में, हमने चर को इनिशियलाइज़ कियाy साथ: = ऑपरेटर, जबकि x = ऑपरेटर का उपयोग करके आरंभ किया जाता है।

package main

import "fmt"

func main() {
   var x float64 = 20.0

   y := 42 
   fmt.Println(x)
   fmt.Println(y)
   fmt.Printf("x is of type %T\n", x)
   fmt.Printf("y is of type %T\n", y)	
}

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

20
42
x is of type float64
y is of type int

गो में मिश्रित परिवर्तनीय घोषणा

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

उदाहरण

package main

import "fmt"

func main() {
   var a, b, c = 3, 4, "foo"  
	
   fmt.Println(a)
   fmt.Println(b)
   fmt.Println(c)
   fmt.Printf("a is of type %T\n", a)
   fmt.Printf("b is of type %T\n", b)
   fmt.Printf("c is of type %T\n", c)
}

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

3
4
foo
a is of type int
b is of type int
c is of type string

गो और लवलीन गो में

गो में दो प्रकार के भाव हैं -

  • lvalue- अभिव्यक्ति जो एक स्मृति स्थान को संदर्भित करती है उसे "लवल्यू" अभिव्यक्ति कहा जाता है। एक लैवल्यू, बायें हाथ या दाईं ओर एक असाइनमेंट के रूप में दिखाई दे सकता है।

  • rvalue- रिवाल्यू शब्द एक डेटा मान को संदर्भित करता है जो मेमोरी में कुछ पते पर संग्रहीत होता है। एक अवतरण एक ऐसी अभिव्यक्ति है जिसमें कोई मान निर्दिष्ट नहीं किया जा सकता है जिसका अर्थ है कि एक दायीं ओर एक लकीर दिखाई दे सकती है, लेकिन असाइनमेंट के बाईं ओर नहीं।

चर अंतराल हैं और इसलिए एक असाइनमेंट के बाईं ओर दिखाई दे सकते हैं। न्यूमेरिकल शाब्दिक नियम हैं और इसलिए इन्हें असाइन नहीं किया जा सकता है और यह बाईं ओर नहीं दिखाई दे सकता है।

निम्नलिखित कथन मान्य है -

x = 20.0

निम्नलिखित कथन मान्य नहीं है। यह संकलन-समय त्रुटि उत्पन्न करेगा -

10 = 20