उद्देश्य-सी चर
एक चर कुछ भी नहीं है लेकिन एक भंडारण क्षेत्र को दिया गया नाम है जो हमारे कार्यक्रमों में हेरफेर कर सकता है। ऑब्जेक्टिव-सी में प्रत्येक चर का एक विशिष्ट प्रकार है, जो चर की स्मृति के आकार और लेआउट को निर्धारित करता है; मूल्यों की सीमा जो उस मेमोरी में संग्रहीत की जा सकती है; और परिचालनों का सेट जो चर पर लागू किया जा सकता है।
एक चर का नाम अक्षरों, अंकों और अंडरस्कोर वर्ण से बना हो सकता है। यह या तो एक पत्र या एक अंडरस्कोर से शुरू होना चाहिए। ऊपरी और निचले अक्षर अलग होते हैं क्योंकि ऑब्जेक्टिव-सी केस-संवेदी होता है। पिछले अध्याय में बताए गए मूल प्रकारों के आधार पर, निम्नलिखित बुनियादी चर प्रकार होंगे -
अनु क्रमांक। | टाइप और विवरण |
---|---|
1 | char आमतौर पर एक एकल ओकटेट (एक बाइट)। यह एक पूर्णांक प्रकार है। |
2 | int मशीन के लिए पूर्णांक का सबसे प्राकृतिक आकार। |
3 | float एकल-सटीक फ़्लोटिंग पॉइंट मान। |
4 | double एक डबल-सटीक फ़्लोटिंग पॉइंट मान। |
5 | void प्रकार की अनुपस्थिति का प्रतिनिधित्व करता है। |
ऑब्जेक्टिव-सी प्रोग्रामिंग भाषा कई अन्य प्रकार के चर को भी परिभाषित करने की अनुमति देती है, जिसे हम बाद के अध्यायों जैसे Enumeration, Pointer, Array, Structure, Union आदि में कवर करेंगे। इस अध्याय के लिए, हम केवल मूल चर प्रकारों का अध्ययन करते हैं।
उद्देश्य-सी में चर परिभाषा
एक चर परिभाषा का मतलब संकलक को यह बताना है कि चर के लिए भंडारण कहाँ और कितना बनाना है। एक चर परिभाषा एक डेटा प्रकार को निर्दिष्ट करती है और इसमें उस प्रकार के एक या अधिक चर की सूची शामिल होती है -
type variable_list;
यहाँ, type एक मान्य ऑब्जेक्टिव-सी डेटा प्रकार होना चाहिए जिसमें चार, 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 होता है); अन्य सभी चर का प्रारंभिक मूल्य अपरिभाषित है।
उद्देश्य-सी में परिवर्तनीय घोषणा
एक चर घोषणा संकलक को आश्वासन देती है कि दिए गए प्रकार और नाम के साथ एक चर मौजूद है ताकि संकलक चर के बारे में पूर्ण विवरण की आवश्यकता के बिना आगे संकलन के लिए आगे बढ़े। एक चर घोषणा के संकलन के समय ही इसका अर्थ होता है, प्रोग्राम के लिंकिंग के समय कंपाइलर को वास्तविक परिवर्तनीय घोषणा की आवश्यकता होती है।
एक चर घोषणा उपयोगी है जब आप कई फ़ाइलों का उपयोग कर रहे हैं और आप अपने चर को फ़ाइलों में से एक में परिभाषित करते हैं, जो कार्यक्रम के लिंकिंग के समय उपलब्ध होगा। आप उपयोग करेंगेexternकिसी भी स्थान पर एक चर घोषित करने के लिए कीवर्ड। यद्यपि आप अपने उद्देश्य-सी कार्यक्रम में कई बार एक चर घोषित कर सकते हैं, लेकिन इसे केवल एक बार फ़ाइल, फ़ंक्शन या कोड के ब्लॉक में परिभाषित किया जा सकता है।
उदाहरण
निम्नलिखित उदाहरण का प्रयास करें, जहां चर शीर्ष पर घोषित किए गए हैं, लेकिन उन्हें मुख्य कार्य के अंदर परिभाषित और आरम्भ किया गया है -
#import <Foundation/Foundation.h>
// 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;
NSLog(@"value of c : %d \n", c);
f = 70.0/3.0;
NSLog(@"value of f : %f \n", f);
return 0;
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
2013-09-07 22:43:31.695 demo[14019] value of c : 30
2013-09-07 22:43:31.695 demo[14019] value of f : 23.333334
समान अवधारणा फ़ंक्शन घोषणा पर लागू होती है जहां आप इसकी घोषणा के समय एक फ़ंक्शन नाम प्रदान करते हैं और इसकी वास्तविक परिभाषा कहीं और दी जा सकती है। निम्नलिखित उदाहरण में, इसे C फ़ंक्शन का उपयोग करके समझाया गया है और जैसा कि आप जानते हैं कि ऑब्जेक्टिव-सी C स्टाइल फ़ंक्शन का भी समर्थन करता है -
// function declaration
int func();
int main() {
// function call
int i = func();
}
// function definition
int func() {
return 0;
}
वस्तुनिष्ठ-सी में लवलीन और नियम
Objective-C में दो तरह के भाव होते हैं -
lvalue- अभिव्यक्ति जो एक स्मृति स्थान को संदर्भित करती है उसे "लवल्यू" अभिव्यक्ति कहा जाता है। एक लैवल्यू किसी असाइनमेंट के बाएं-हाथ या दाईं ओर के रूप में दिखाई दे सकता है।
rvalue- रिवाल्यू शब्द एक डेटा मान को संदर्भित करता है जो मेमोरी में कुछ पते पर संग्रहीत होता है। एक अवतरण एक ऐसी अभिव्यक्ति है जिसमें एक मान निर्दिष्ट नहीं किया जा सकता है जिसका अर्थ है कि एक दायें दाईं ओर दिखाई दे सकता है - लेकिन एक असाइनमेंट के बाईं ओर नहीं।
चर अंतराल हैं और इसलिए एक असाइनमेंट के बाईं ओर दिखाई दे सकते हैं। न्यूमेरिकल शाब्दिक नियम हैं और इसलिए इन्हें असाइन नहीं किया जा सकता है और यह बाईं ओर नहीं दिखाई दे सकता है। निम्नलिखित एक मान्य कथन है -
int g = 20;
लेकिन निम्नलिखित एक मान्य कथन नहीं है और यह संकलन-समय त्रुटि उत्पन्न करेगा -
10 = 20;