Objective-C 로그 처리

NSLog 방법

로그를 출력하기 위해 Hello World 예제에서 바로 사용한 Objective-C 프로그래밍 언어의 NSLog 메서드를 사용합니다.

"Hello World"라는 단어를 인쇄하는 간단한 코드를 살펴 보겠습니다.

#import <Foundation/Foundation.h>

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

이제 프로그램을 컴파일하고 실행하면 다음과 같은 결과를 얻을 수 있습니다.

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

라이브 앱에서 로그 비활성화

응용 프로그램에서 사용하는 NSLog는 장치의 로그에 인쇄되므로 라이브 빌드에서 로그를 인쇄하는 것은 좋지 않습니다. 따라서 로그 인쇄를 위해 유형 정의를 사용하며 아래와 같이 사용할 수 있습니다.

#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