C ++ चर प्रकार
एक चर हमें नामित भंडारण प्रदान करता है जो हमारे कार्यक्रमों में हेरफेर कर सकता है। C ++ में प्रत्येक चर का एक विशिष्ट प्रकार है, जो चर की स्मृति के आकार और लेआउट को निर्धारित करता है; मूल्यों की सीमा जो उस मेमोरी में संग्रहीत की जा सकती है; और परिचालनों का सेट जो चर पर लागू किया जा सकता है।
एक चर का नाम अक्षरों, अंकों और अंडरस्कोर वर्ण से बना हो सकता है। यह या तो एक पत्र या एक अंडरस्कोर से शुरू होना चाहिए। ऊपरी और निचले अक्षर अलग हैं क्योंकि C ++ केस-संवेदी है -
C ++ में मूल प्रकार के चर निम्नलिखित हैं जैसा कि पिछले अध्याय में बताया गया है -
अनु क्रमांक | टाइप और विवरण |
---|---|
1 | bool स्टोर या तो सही है या गलत है। |
2 | char आमतौर पर एक एकल ओकटेट (एक बाइट)। यह एक पूर्णांक प्रकार है। |
3 | int मशीन के लिए पूर्णांक का सबसे प्राकृतिक आकार। |
4 | float एकल-सटीक फ़्लोटिंग पॉइंट मान। |
5 | double एक डबल-सटीक फ़्लोटिंग पॉइंट मान। |
6 | void प्रकार की अनुपस्थिति का प्रतिनिधित्व करता है। |
7 | wchar_t एक विस्तृत वर्ण प्रकार। |
C ++ विभिन्न प्रकार के अन्य चर को भी परिभाषित करने की अनुमति देता है, जिसे हम बाद के अध्यायों में कवर करेंगे Enumeration, Pointer, Array, Reference, Data structures, तथा Classes।
निम्नलिखित अनुभाग में विभिन्न प्रकार के चर को परिभाषित, घोषित और उपयोग करने के तरीके शामिल होंगे।
C ++ में चर परिभाषा
एक चर परिभाषा संकलक को बताती है कि चर के लिए कहां और कितना संग्रहण बनाना है। एक चर परिभाषा एक डेटा प्रकार को निर्दिष्ट करती है, और इसमें उस प्रकार के एक या अधिक चर की सूची शामिल होती है -
type variable_list;
यहाँ, type एक मान्य C ++ डेटा प्रकार होना चाहिए, जिसमें char, w_char, int, float, double, bool या कोई उपयोगकर्ता-निर्धारित ऑब्जेक्ट, आदि शामिल हैं, और परिभाषित variable_listअल्पविराम द्वारा अलग किए गए एक या एक से अधिक पहचानकर्ता नाम शामिल हो सकते हैं। कुछ मान्य घोषणाएँ यहाँ दिखाई गई हैं -
int i, j, k;
char c, ch;
float f, salary;
double d;
रेखा int i, j, k;दोनों घोषित करता है और चर को परिभाषित करता है i, j और k; जो संकलक को निर्देश देता है कि मैं i, j और k प्रकार के वैरिएबल बनाएं।
चर को उनकी घोषणा में आरंभीकृत किया जा सकता है (प्रारंभिक मूल्य सौंपा गया है)। इनिशियलाइज़र में एक समरूप चिन्ह होता है, जिसके बाद एक स्थिर अभिव्यक्ति होती है -
type variable_name = value;
कुछ उदाहरण हैं -
extern int d = 3, f = 5; // declaration of d and f.
int d = 3, f = 5; // definition and initializing d and f.
byte z = 22; // definition and initializes z.
char x = 'x'; // the variable x has the value 'x'.
इनिशियलाइज़र के बिना परिभाषा के लिए: स्थिर भंडारण अवधि वाले वेरिएबल को संक्षेप में NULL के साथ आरंभीकृत किया जाता है (सभी बाइट्स का मान 0 होता है); अन्य सभी चर का प्रारंभिक मूल्य अपरिभाषित है।
C ++ में परिवर्तनीय घोषणा
एक चर घोषणा संकलक को आश्वासन देती है कि दिए गए प्रकार और नाम के साथ एक चर मौजूद है ताकि संकलक चर के बारे में पूर्ण विवरण की आवश्यकता के बिना आगे संकलन के लिए आगे बढ़े। एक चर घोषणा के संकलन के समय इसका अर्थ होता है, संकलक को कार्यक्रम के लिंकिंग के समय वास्तविक चर परिभाषा की आवश्यकता होती है।
एक चर घोषणा उपयोगी है जब आप कई फ़ाइलों का उपयोग कर रहे हैं और आप अपने चर को उन फ़ाइलों में से एक में परिभाषित करते हैं जो कार्यक्रम के लिंकिंग के समय उपलब्ध होंगी। आप उपयोग करेंगेexternकिसी भी स्थान पर एक चर घोषित करने के लिए कीवर्ड। यद्यपि आप अपने C ++ प्रोग्राम में एक चर को कई बार घोषित कर सकते हैं, लेकिन इसे केवल एक बार फ़ाइल, फ़ंक्शन या कोड के ब्लॉक में परिभाषित किया जा सकता है।
उदाहरण
निम्नलिखित उदाहरण का प्रयास करें जहां शीर्ष पर एक चर घोषित किया गया है, लेकिन इसे मुख्य कार्य के अंदर परिभाषित किया गया है -
#include <iostream>
using namespace std;
// Variable declaration:
extern int a, b;
extern int c;
extern float f;
int main () {
// Variable definition:
int a, b;
int c;
float f;
// actual initialization
a = 10;
b = 20;
c = a + b;
cout << c << endl ;
f = 70.0/3.0;
cout << f << endl ;
return 0;
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
30
23.3333
समान अवधारणा फ़ंक्शन घोषणा पर लागू होती है जहां आप इसकी घोषणा के समय एक फ़ंक्शन नाम प्रदान करते हैं और इसकी वास्तविक परिभाषा कहीं और दी जा सकती है। उदाहरण के लिए -
// function declaration
int func();
int main() {
// function call
int i = func();
}
// function definition
int func() {
return 0;
}
लवलीन और रिवल्यूशन
C ++ में दो तरह के भाव हैं -
lvalue- अभिव्यक्ति जो एक स्मृति स्थान को संदर्भित करती है उसे "लवल्यू" अभिव्यक्ति कहा जाता है। एक लैवल्यू किसी असाइनमेंट के बाएं-हाथ या दाईं ओर के रूप में दिखाई दे सकता है।
rvalue- रिवाल्यू शब्द एक डेटा मान को संदर्भित करता है जो मेमोरी में कुछ पते पर संग्रहीत होता है। एक अवतरण एक ऐसी अभिव्यक्ति है जिसमें एक मान निर्दिष्ट नहीं किया जा सकता है जिसका अर्थ है कि एक दायें दाईं ओर दिखाई दे सकता है - लेकिन एक असाइनमेंट के बाईं ओर नहीं।
वेरिएबल्स अंतराल हैं और इसलिए एक असाइनमेंट के बाईं ओर दिखाई दे सकते हैं। न्यूमेरिकल शाब्दिक नियम हैं और इसलिए इन्हें असाइन नहीं किया जा सकता है और यह बाईं ओर नहीं दिखाई दे सकता है। निम्नलिखित एक मान्य कथन है -
int g = 20;
लेकिन निम्नलिखित एक मान्य कथन नहीं है और यह संकलन-समय त्रुटि उत्पन्न करेगा -
10 = 20;