Skip to main content

What is lexical scope?


I want a brief intro to lexical scope



Source: Tips4allCCNA FINAL EXAM

Comments

  1. I understand them through examples :)

    Static or Lexical Scope, in C-like syntax ::

    void fun()
    {
    int x = 5;

    void fun2()
    {
    printf("%d", x);
    }
    }


    every inner level can access its outer levels.

    there is another way, called Dynamic Scope used by first implementation of Lisp,
    again in C-like Syntax ::

    void fun()
    {
    printf("%d", x);
    }

    void dummy1()
    {
    int x = 5;

    fun();
    }

    void dummy2()
    {
    int x = 10;

    fun();
    }


    here fun can either access x in dummy1 or dummy2, or any x in any function that call fun with x declared in it.

    dummy1();


    will print 5

    dummy2();


    will print 10

    the first one is called static because it can be deduced at compile-time,
    the second is called dynamic because the the outer scope is dynamic and depends on the chain call of the functions.

    I find static scoping easier for the eye. Most languages went this way eventually even Lisp (can do both, right?). Dynamic scoping is like passing references of all variables to the called function.
    An example of why the compiler can not deduce the outer dynamic scope of a function, consider our last example, if we write something like this ::

    if(/* some condition */)
    dummy1();
    else
    dummy2();


    the call chain depends on a run time condition. If it is true, then the call chain looks like ::

    dummy1 --> fun()


    If the condition is false ::

    dummy2 --> fun()


    The outer scope of fun in both cases is the caller plus the caller of the caller and so on.

    Just to mention that C language does not allow nested functions nor dynamic scoping.

    ReplyDelete
  2. Lexical (AKA static) scoping refers to determining a variable's scope based solely on its position within the textual corpus of code. A variable always refers to its top-level environment. It's good to understand it in relation to dynamic scope.

    ReplyDelete
  3. Scope defines the area, where functions, variables and such are available. The availability of a variable for example is defined within its the context, let's say the function, file, or object, they are defined in. We usually call these local variables.

    The lexical part means that you can derive the scope from reading the source code.

    Lexical scope is also known as static scope.

    Dynamic scope defines global variables that can be called or referenced from anywhere after being defined. Sometimes they are called global variables, even though global variables in most programmin languages are of lexical scope. This means, it can be derived from reading the code that the variable is available in this context. Maybe one has to follow a uses or includes clause to find the instatiation or definition, but the code/compiler knows about the variable in this place.

    In dynamic scoping, by contrast, you search in the local function first, then you search in the function that called the local function, then you search in the function that called that function, and so on, up the call stack. "Dynamic" refers to change, in that the call stack can be different every time a given function is called, and so the function might hit different variables depending on where it is called from. (see here)

    To see an interesting example for dynamic scope see here.

    For further details see here and here.

    Some examples in Delphi/Object Pascal

    Delphi has lexical scope.

    unit Main;
    uses aUnit; // makes available all variables in interface section of aUnit

    interface

    var aGlobal: string; // global in the scope of all units that use Main;
    type
    TmyClass = class
    strict private aPrivateVar: Integer; // only known by objects of this class type
    // lexical: within class definition,
    // reserved word private
    public aPublicVar: double; // known to everyboday that has access to a
    // object of this class type
    end;

    implementation

    var aLocalGlobal: string; // known to all functions following
    // the definition in this unit

    end.


    The closest Delphi gets to dynamic scope is the RegisterClass()/GetClass() function pair. For its use see here.

    Let's say that the time RegisterClass([TmyClass]) is called to register a certain class cannot be predicted by reading the code (it gets called in a button click method called by the user), code calling GetClass('TmyClass') will get a result or not. The call to RegisterClass() does not have to be in the lexical scope of the unit using GetClass();

    Another possibility for dynamic scope are anonymous methods (closures) in Delphi 2009, as they know the variables of their calling function. It does not follow the calling path from there recursively and therefore is not fully dynamic.

    ReplyDelete
  4. Lets try the shortest possible definition:

    Lexical Scoping (aka Closure) defines how variable names are resolved in nested functions: inner functions contain the scope of parent functions even if the parent function has returned.

    That's all there is to it! To help myself understand what this means, I wrote an in depth blog post about function scope and lexical scoping in JavaScript which can be found here. Maybe this could serve someone else too.

    ReplyDelete
  5. Lexical scoping: Variables declared outside of a function are global variables and are visible everywhere in a JavaScript program. Variables declared inside a function have function scope and are visible only to code that appears inside that function.

    ReplyDelete
  6. Here is an explanation in the case of R.

    ReplyDelete

Post a Comment

Popular posts from this blog

Why is this Javascript much *slower* than its jQuery equivalent?

I have a HTML list of about 500 items and a "filter" box above it. I started by using jQuery to filter the list when I typed a letter (timing code added later): $('#filter').keyup( function() { var jqStart = (new Date).getTime(); var search = $(this).val().toLowerCase(); var $list = $('ul.ablist > li'); $list.each( function() { if ( $(this).text().toLowerCase().indexOf(search) === -1 ) $(this).hide(); else $(this).show(); } ); console.log('Time: ' + ((new Date).getTime() - jqStart)); } ); However, there was a couple of seconds delay after typing each letter (particularly the first letter). So I thought it may be slightly quicker if I used plain Javascript (I read recently that jQuery's each function is particularly slow). Here's my JS equivalent: document.getElementById('filter').addEventListener( 'keyup', function () { var jsStart = (new Date).getTime()...

Is it possible to have IF statement in an Echo statement in PHP

Thanks in advance. I did look at the other questions/answers that were similar and didn't find exactly what I was looking for. I'm trying to do this, am I on the right path? echo " <div id='tabs-".$match."'> <textarea id='".$match."' name='".$match."'>". if ($COLUMN_NAME === $match) { echo $FIELD_WITH_COLUMN_NAME; } else { } ."</textarea> <script type='text/javascript'> CKEDITOR.replace( '".$match."' ); </script> </div>"; I am getting the following error message in the browser: Parse error: syntax error, unexpected T_IF Please let me know if this is the right way to go about nesting an IF statement inside an echo. Thank you.