NSLog and You: Learning How and When to Use It

NSLog and You: Learning How and When to Use It


NSLog is a very useful function call that iOS developers are able to utilize and it is one of the most common development tools used to debug iOS apps. Among other things, NSLog can be used to check the value of variables, log any notes that you need to make, and check for errors when you do not have a debugger available. While NSLog is fairly handy, it is not a universal tool that can solve all of your programming problems. An experienced developer knows when NSLog is the best tool available to them as well as the potential downsides of utilizing NSLog over other options. Beginner developers should strive to commit these facts to memory in order to maximize their efficiency with creating and improving apps.

When to Use NSLog

Determining exactly when it is best to use NSLog is not quite an exact science. The key idea is to find a balance between how much information you are going to need and how often you will need that information. When thinking about the balance between these two factors, it is crucial to keep in mind that it is better to have too much information than not enough. Under any circumstances you want to be sure that you have at least the barebones minimum required to keep everything functioning.

Exactly what you want to use NSLog for will depend on what your current needs are. For example, you may want to view controller life-cycles in order to track user flow to your app. On the other hand, an app that still needs a bit of work done could use NSLog to monitor server requests and error responses that result from those requests.

How to Use NSLog

Using NSLog for debugging you are is very simple, you just need to call NSLog Objective-C function like this:

[code language=”objc”]
int number = 25;
NSString *text = @"Apple";
NSLog(@"Number value is %d and text is %@.", variable, text);


The NSLog function uses the same format specifiers than printf function. You have the full list in the Apple Documentation

Downsides to NSLog

While NSLog is handy, it is not perfect. There are a few key issues that can cause problems some developers may consider too bothersome to make NSLog worth utilizing.


NSLog is synchronous, i.e. slow. Luckily, there are ways to disable NSLog and work around this particular issue. One method is to use a debug configuration and replace NSLogs with DLogs. This will cause debug messages to pop up while testing and debugging your app; when you release a beta or final version of the app the DLog lines become empty and will no longer do anything.

What Are 1000 Apps Doing to Reduce Their Bugs to Zero?

Down to Zero is a practical guide to solving bugs. Our team has been developing mobile apps for over a decade and we'd like to share some tips we've picked up along the way.

Get the Ebook for Free

Down to Zero Ebook

Start by finding the ‘yourProjectName-prefix.pch’ file and add three lines to the end of the .pch file:

[code language=”objc”]

#ifdef DEBUG
#define DLog(…) NSLog(__VA_ARGS__)
#define DLog(…) /* */


Then test the difference between the debug version and release version of your app. If you no longer see any NSLog output in the release version, you have implemented this feature correctly. There are many options available for eliminating NSLog’s effects on performance, so do not panic if neither of these two options work for one particular project or another.

No Intelligence

NSLogs do not contain any kind of log classification. This makes it difficult to tell the difference between errors, warnings, and other information. Having tags and different log levels would be extremely useful, but that is simply not how NSLog works.

Remote Access

NSLog only works when your device is physically attached to your computer; there is not an option for remote access. This lack of functionality can be extremely frustrating for developers who are consistently on the go and do not always have the ability to sit down and get everything hooked up when they find themselves with a few extra minutes to work on their latest project.

Bugfender, a Better NSLog

Bugfender has many of the same features as NSLog, but with superior performance levels due to increased functionality. On top of being able to do everything that NSLog is capable of, Bugfender provides several additional features that NSLog does not offer. All logs are processed on a background thread, saving developers the trouble of having to disable NSLogs for beta or full release versions of apps. Bugfender is also able to acquire logs from remote devices, even if the app has been used offline. Furthermore, these logs feature tags and levels that make the files easy to navigate, allowing developers to locate error messages or other pieces of information with ease.

NSLog is handy and has been around for a very long time, but it is past its heyday and many developers are beginning to realize that it may be time to put old NSLog out to pasture. There are more modern technologies that can do NSLog’s same job better and Bugfender is at the forefront of these new, innovative solutions. Integrating and using Bugfender is a quick and simple process, so be sure to give it a try today! Once you see how much more it has to offer over NSLog, you will wonder why you ever waited to switch over.

Trusted By

as_credito_agricola as_tesco as_taxify as_websummit Created with Sketch. Continental as_starbucks Rakuten

Already Trusted by Thousands

Bugfender is the best remote logger for mobile and web apps.

Get Started for Free, No Credit Card Required