उद्देश्य-सी लॉग हैंडलिंग

NSLog विधि

लॉग प्रिंट करने के लिए, हम ऑब्जेक्टिव-सी प्रोग्रामिंग भाषा में NSLog पद्धति का उपयोग करते हैं, जिसका उपयोग हमने हैलो वर्ल्ड उदाहरण से किया है।

आइए एक सरल कोड देखें, जो "हैलो वर्ल्ड" शब्दों को प्रिंट करेगा -

#import <Foundation/Foundation.h>

int main() {
   NSLog(@"Hello, World! \n");
   return 0;
}

अब, जब हम प्रोग्राम को संकलित करते हैं और चलाते हैं, तो हमें निम्नलिखित परिणाम मिलेंगे।

2013-09-16 00:32:50.888 demo[16669] Hello, World!

लाइव ऐप्स में लॉग को अक्षम करना

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

#import <Foundation/Foundation.h>

#if DEBUG == 0
#define DebugLog(...)
#elif DEBUG == 1
#define DebugLog(...) NSLog(__VA_ARGS__)
#endif

int main() {
   DebugLog(@"Debug log, our custom addition gets \
   printed during debug only" );
   NSLog(@"NSLog gets printed always" );     
   return 0;
}

अब, जब हम प्रोग्राम को डिबग मोड में संकलित और चलाते हैं, तो हमें निम्न परिणाम मिलेगा।

2013-09-11 02:47:07.723 demo[618] Debug log, our custom addition gets printed during debug only
2013-09-11 02:47:07.723 demo[618] NSLog gets printed always

अब, जब हम प्रोग्राम को रिलीज़ मोड में संकलित और चलाते हैं, तो हमें निम्नलिखित परिणाम मिलेंगे।

2013-09-11 02:47:45.248 demo[3158] NSLog gets printed always