Lazy definition function

This has a nice name – a lazy function definition. A lazy function is one that pretends to work but it doesn't really.

It does some work initially and then caches the result. Then on consecutive calls it only returns the pre-computed result, it doesn’t really do anything.

In order to do so, the function redefines itself with a new implementation, one that simply points to the computed result.

function lazy() {
    var result = 2 + 2;
    lazy = function() {
        return result;
    };
    return lazy();
}

lazy(); // 4
lazy(); // 4

Tags: ,

4 Responses to “Lazy definition function”

  1. nghia Says:

    Hi Stoyan Stefanov
    please answer me a question : What is Lazy definition function used for? and when we use it ?

  2. 澄净的禅院 » Blog Archive » Lazy Function Definition Says:

    […] http://www.jspatterns.com/lazy-definition-function/ […]

  3. Yaroslav Says:

    What is the difference between lazy definition functions and closures? They looks too similar.

  4. Rob Says:

    This pattern can be useful when dealing with cross-browser code. For instance, getting the XmlHttpRequest() object. You could wrap the code for searching the correct object in the initial code and return the caching of the final object. Like this for instance:

    ns.getXHRObject = function() {

    if (typeof(window.XMLHttpRequest) === “function”) {
    // Native object exists
    ns.getXHRObject = function() {
    return new window.XMLHttpRequest();
    };
    }
    else {
    // Do your older browser searching here and replace the outcome with
    // a similar new function definition as above..
    }
    };

    Next time the function is called, the caching is returned. So execution will be faster the
    second time.. imagine doing this for functions which will do lots of logic over and over again with the same outcome.. this can save lots of cpu cycles.. and better yet, improve user experience..

Leave a Reply