COP4020 Programming Languages Names, Scopes, and Bindings Prof. Xin Yuan.

Slides:



Advertisements
Similar presentations
CSC 4181 Compiler Construction Scope and Symbol Table.
Advertisements

Programming Paradigms Introduction. 6/15/2005 Copyright 2005, by the authors of these slides, and Ateneo de Manila University. All rights reserved. L1:
Names, Bindings, Type Checking, and Scopes
ISBN Chapter 10 Implementing Subprograms.
1 Pertemuan 20 Run-Time Environment Matakuliah: T0174 / Teknik Kompilasi Tahun: 2005 Versi: 1/6.
Run time vs. Compile time
Chapter 9: Subprogram Control
CSC321: Programming Languages Names Chapter 4: Names 4.1 Syntactic Issues 4.2 Variables 4.3 Scope 4.4 Symbol Table 4.5 Resolving References 4.6 Dynamic.
ISBN Chapter 10 Implementing Subprograms –Nested Subprograms –Blocks –Implementing Dynamic Scoping.
COP4020 Programming Languages
Names and Binding In procedural programming, you write instructions the manipulate the “state” of the process where the “state” is the collection of variables.
CS 355 – PROGRAMMING LANGUAGES Dr. X. Copyright © 2012 Addison-Wesley. All rights reserved.1-2 Topics Scope Scope and Lifetime Referencing Environments.
COMPILERS Semantic Analysis hussein suleman uct csc3005h 2006.
Names and Scope. Scope Suppose that a name is used many times for different entities in text of the program, or in the course of execution. When the name.
1 Names, Scopes and Bindings Aaron Bloomfield CS 415 Fall
1 Scope Rules (Section 3.3) CSCI 431 Programming Languages Fall 2003 A compilation of material developed by Felix Hernandez-Campos and Michael Scott.
Basic Semantics Associating meaning with language entities.
1 Scope Scope describes the region where an identifier is known, and semantic rules for this.
Runtime Organization.
1 Type Checking Type checking ensures that the operands and the operator are of compatible types Generalized to include subprograms and assignments Compatible.
COP4020 Programming Languages Subroutines and Parameter Passing Prof. Xin Yuan.
CSC3315 (Spring 2008)1 CSC 3315 Subprograms Hamid Harroud School of Science and Engineering, Akhawayn University
COP4020 Programming Languages Names, Scopes, and Bindings Prof. Xin Yuan.
Implementing Subprograms What actions must take place when subprograms are called and when they terminate? –calling a subprogram has several associated.
COMP3190: Principle of Programming Languages
Structure of Programming Languages Names, Bindings, Type Checking, and Scopes.
Concepts of programming languages Chapter 5 Names, Bindings, and Scopes Lec. 12 Lecturer: Dr. Emad Nabil 1-1.
COP4020 Programming Languages Names, Scopes, and Bindings Prof. Robert van Engelen.
Programming Languages and Design Lecture 6 Names, Scopes and Binding Instructor: Li Ma Department of Computer Science Texas Southern University, Houston.
1 Bindings. 2 Outline Preliminaries Scope  Block structure  Visibility Static vs. dynamic binding Declarations and definitions More about blocks The.
1 Run-Time Environments Chapter 7 COP5621 Compiler Construction Copyright Robert van Engelen, Florida State University, 2005.
1 Structure of Compilers Lexical Analyzer (scanner) Modified Source Program Parser Tokens Semantic Analysis Syntactic Structure Optimizer Code Generator.
RUNTIME ENVIRONMENT AND VARIABLE BINDINGS How to manage local variables.
COP4020 Programming Languages Names, Scopes, and Bindings Prof. Robert van Engelen (modified by Prof. Em. Chris Lacher)
1 CSC 533: Programming Languages Spring 2014 Subprogram implementation  subprograms (procedures/functions/subroutines)  subprogram linkage  parameter.
CHAPTER 4 VARIABLES & BINDING SUNG-DONG KIM DEPT. OF COMPUTER ENGINEERING, HANSUNG UNIVERSITY.
Run-Time Environments Presented By: Seema Gupta 09MCA102.
Code Generation Instruction Selection Higher level instruction -> Low level instruction Register Allocation Which register to assign to hold which items?
Advanced Programming in C
Implementing Subprograms
Run-Time Environments Chapter 7
Name Spaces: ALL versus OOL
CS 326 Programming Languages, Concepts and Implementation
Chapter 4 Variables & Binding
Type Checking, and Scopes
CS 326 Programming Languages, Concepts and Implementation
Implementing Subprograms
Run-Time Environments
Implementing Subprograms
Names, Scopes, and Bindings: Scopes
Names, Binding, and Scope
CSE 3302 Programming Languages
Scope of Variables.
Scope, Visibility, and Lifetime
Implementing Subprograms
COP4020 Programming Languages
CSC 533: Programming Languages Spring 2015
Run-Time Environments
Implementing Subprograms
Binding Times Binding is an association between two things Examples:
Scope.
UNIT V Run Time Environments.
Names and Binding In Text: Chapter 5.
CSE 3302 Programming Languages
COMPILERS Semantic Analysis
Lecture 6: Names (Revised based on the Tucker’s slides) 5/27/2019
CSC 533: Programming Languages Spring 2018
CSC 533: Programming Languages Spring 2019
Types and Related Issues
Implementing Subprograms
Presentation transcript:

COP4020 Programming Languages Names, Scopes, and Bindings Prof. Xin Yuan

COP4020 Spring /13/2015 Overview Scope rules Static versus dynamic scoping

COP4020 Spring /13/2015 Scope Scope is the textual region of a program in which a name-to-object binding is active Statically scoped language: the scope of bindings is determined at compile time  Used by almost all but a few programming languages  More intuitive to user compared to dynamic scoping Dynamically scoped language: the scope of bindings is determined at run time  Used in Lisp (early versions), APL, Snobol, and Perl (selectively) Scoping in action: see scope.cpp

COP4020 Spring /13/2015 Effect of Static Scoping The following pseudo-code program demonstrates the effect of scoping on variable bindings: a:integer procedure first a:=1 procedure second a:integer first() procedure main a:=2 second() write_integer(a) a:integer main() a:=2 second() a:integer first() a:=1 write_integer(a) Program execution: Program prints “1” binding

COP4020 Spring /13/2015 Effect of Dynamic Scoping The following pseudo-code program demonstrates the effect of scoping on variable bindings: a:integer procedure first a:=1 procedure second a:integer first() procedure main a:=2 second() write_integer(a) a:integer main() a:=2 second() a:integer first() a:=1 write_integer(a) Program execution: Program prints “2” binding Binding depends on execution

COP4020 Spring /13/2015 Static Scoping The bindings between names and objects can be determined by examination of the program text Scope rules of a program language define the scope of variables and subroutines, which is the region of program text in which a name-to-object binding is usable  Early Basic: all variables are global and visible everywhere  Fortran 77: the scope of a local variable is limited to a subroutine; the scope of a global variable is the whole program text unless it is hidden by a local variable declaration with the same variable name  Algol 60, Pascal, and Ada: these languages allow nested subroutines definitions and adopt the closest nested scope rule with slight variations in implementation

COP4020 Spring /13/2015 Closest Nested Scope Rule To find the object referenced by a given name:  Look for a declaration in the current innermost scope  If there is none, look for a declaration in the immediately surrounding scope, etc. procedure P1(A1:T1) var X:real;... procedure P2(A2:T2);... procedure P3(A3:T3);... begin (* body of P3: P3,A3,P2,A2,X of P1,P1,A1 are visible *) end;... begin (* body of P2: P3,P2,A2,X of P1,P1,A1 are visible *) end; procedure P4(A4:T4);... function F1(A5:T5):T6; var X:integer;... begin (* body of F1: X of F1,F1,A5,P4,A4,P2,P1,A1 are visible *) end;... begin (* body of P4: F1,P4,A4,P2,X of P1,P1,A1 are visible *) end;... begin (* body of P1: X of P1,P1,A1,P2,P4 are visible *) end

COP4020 Spring /13/2015 Static Scope Implementation with Static Links With the Closest Nested Scope Rule, the program can only refer to variables that are alive: the variable must have been stored in the frame of a subroutine If a variable is not in the local scope, we are sure there is a frame for the surrounding scope somewhere below on the stack:  The current subroutine can only be called when it was visible  The current subroutine is visible only when the surrounding scope is active Each frame on the stack contains a static link pointing to the frame of the static parent

COP4020 Spring /13/2015 Example Static Links Subroutines C and D are declared nested in B  B is static parent of C and D B and E are nested in A  A is static parent of B and E The fp points to the frame at the top of the stack to access locals The static link in the frame points to the frame of the static parent

COP4020 Spring /13/2015 Static Chains How do we access non-local objects? The static links form a static chain, which is a linked list of static parent frames When a subroutine at nesting level j has a reference to an object declared in a static parent at the surrounding scope nested at level k, then j-k static links forms a static chain that is traversed to get to the frame containing the object The compiler generates code to make these traversals over frames to reach non-local objects

COP4020 Spring /13/2015 Example Static Chains Subroutine A is at nesting level 1 and C at nesting level 3 When C accesses an object of A, 2 static links are traversed to get to A's frame that contains that object

COP4020 Spring /13/2015 Out of Scope Non-local objects can be hidden by local name-to-object bindings and the scope is said to have a hole in which the non-local binding is temporarily inactive but not destroyed Some languages, notably Ada and C++ use qualifiers or scope resolution operators to access non-local objects that are hidden  P1.X in Ada to access variable X of P1 and ::X to access global variable X in C++

COP4020 Spring /13/2015 Out of Scope Example P2 is nested in P1 P1 has a local variable X P2 has a local variable X that hides X in P1 When P2 is called, no extra code is executed to inactivate the binding of X to P1 procedure P1; var X:real; procedure P2; var X:integer begin... (* X of P1 is hidden *) end; begin... end

COP4020 Spring /13/2015 Dynamic Scope Scope rule: the "current" binding for a given name is the one encountered most recently during execution Typically adopted in (early) functional languages that are interpreted With dynamic scope:  Name-to-object bindings cannot be determined by a compiler in general  Easy for interpreter to look up name-to-object binding in a stack of declarations Generally considered to be "a bad programming language feature"  Hard to keep track of active bindings when reading a program text  Most languages are now compiled, or a compiler/interpreter mix

COP4020 Spring /13/2015 Dynamic Scoping Problems In this example, function scaled_score probably does not do what the programmer intended: with dynamic scoping, max_score in scaled_score is bound to foo 's local variable max_score after foo calls scaled_score, which was the most recent binding during execution: max_score:integer function scaled_score(raw_score:integer):real return raw_score/max_score* procedure foo max_score:real := 0... foreach student in class student.percent := scaled_score(student.points) if student.percent > max_score max_score := student.percent

COP4020 Spring /13/2015 Dynamic Scope Implementation with Bindings Stacks Each time a subroutine is called, its local variables are pushed on a stack with their name-to-object binding When a reference to a variable is made, the stack is searched top-down for the variable's name-to-object binding After the subroutine returns, the bindings of the local variables are popped Different implementations of a binding stack are used in programming languages with dynamic scope, each with advantages and disadvantages

COP4020 Spring /13/2015 Static and Dynamic Scope example a : integer; procedure foo a = 10 goo() hoo() write (a) procedure goo a = 20 procedure hoo write(a) procedure main a : integer a = 30 foo() write (a)