Chapter TenModern Programming Languages1 Scope. Chapter TenModern Programming Languages2 Reusing Names Scope is trivial when all names are unique But.

Slides:



Advertisements
Similar presentations
Programming Languages and Paradigms
Advertisements

Programming Languages and Paradigms The C Programming Language.
Programming Paradigms Introduction. 6/15/2005 Copyright 2005, by the authors of these slides, and Ateneo de Manila University. All rights reserved. L1:
Programming Languages Marjan Sirjani 2 2. Language Design Issues Design to Run efficiently : early languages Easy to write correctly : new languages.
Abstract Data Types Data abstraction, or abstract data types, is a programming methodology where one defines not only the data structure to be used, but.
5/15/2015IT 3271 Polymorphism (Ch 8) n A functions that is not fixed is polymorphic n Applies to a wide variety of language features n Most languages have.
Chapter TenModern Programming Languages1 Scope. Chapter TenModern Programming Languages2 Reusing Names n Scope is trivial if you have a unique name for.
Scope Chapter Ten Modern Programming Languages.
Scope Chapter TenModern Programming Languages, 2nd ed.1.
Variables Names Bindings Type Scope. L-Value versus R-Value Not complicated Associated with assignment statements Left hand side represents an address.
CS 330 Programming Languages 10 / 16 / 2008 Instructor: Michael Eckmann.
ISBN Chapter 11 Abstract Data Types and Encapsulation Concepts.
Names and Scopes CS 351. Program Binding We should be familiar with this notion. A variable is bound to a method or current block e.g in C++: namespace.
© 2006 Pearson Addison-Wesley. All rights reserved4-1 Chapter 4 Data Abstraction: The Walls.
Run time vs. Compile time
Chapter 9: Subprogram Control
Data Abstraction and Object- Oriented Programming CS351 – Programming Paradigms.
1 Run time vs. Compile time The compiler must generate code to handle issues that arise at run time Representation of various data types Procedure linkage.
Abstract Data Types and Encapsulation Concepts
Cs164 Prof. Bodik, Fall Symbol Tables and Static Checks Lecture 14.
Scope.
1 Chapter 5: Names, Bindings and Scopes Lionel Williams Jr. and Victoria Yan CSci 210, Advanced Software Paradigms September 26, 2010.
Chapter TwelveModern Programming Languages1 Memory Locations For Variables.
CPS 506 Comparative Programming Languages Names, Scope, Expression.
5-1 Chapter 5: Names, Bindings, Type Checking, and Scopes Variables The Concept of Binding Type Checking Strong Typing Type Compatibility Scope and Lifetime.
Bindings and scope  Bindings and environments  Scope and block structure  Declarations Programming Languages 3 © 2012 David A Watt, University.
1 Names, Scopes and Bindings Aaron Bloomfield CS 415 Fall
10/16/2015IT 3271 All about binding n Variables are bound (dynamically) to values n values must be stored somewhere in the memory. Memory Locations for.
Names. 2 Variables  binding is an association between an entity (such as a variable) and a property (such as its value). A binding is static if the association.
Copyright © 2012 Pearson Education, Inc. Chapter 13: Introduction to Classes.
1 Compiler Construction (CS-636) Muhammad Bilal Bashir UIIT, Rawalpindi.
Basic Semantics Associating meaning with language entities.
1 Scope Scope describes the region where an identifier is known, and semantic rules for this.
Formal Semantics Chapter Twenty-ThreeModern Programming Languages, 2nd ed.1.
Programming Languages by Ravi Sethi Chapter 6: Groupings of Data and Operations.
Programming Languages and Paradigms Imperative Programming.
COP4020 Programming Languages Names, Scopes, and Bindings Prof. Xin Yuan.
User Defined Functions Chapter 7 2 Chapter Topics Void Functions Without Parameters Void Functions With Parameters Reference Parameters Value and Reference.
More About Objects and Methods Chapter 5. Outline Programming with Methods Static Methods and Static Variables Designing Methods Overloading Constructors.
CMP-MX21: Lecture 4 Selections Steve Hordley. Overview 1. The if-else selection in JAVA 2. More useful JAVA operators 4. Other selection constructs in.
Chapter 7 Selection Dept of Computer Engineering Khon Kaen University.
Implementing Subprograms What actions must take place when subprograms are called and when they terminate? –calling a subprogram has several associated.
Chapter 10: Classes and Data Abstraction. Objectives In this chapter, you will: Learn about classes Learn about private, protected, and public members.
Concepts of programming languages Chapter 5 Names, Bindings, and Scopes Lec. 12 Lecturer: Dr. Emad Nabil 1-1.
1 Bindings. 2 Outline Preliminaries Scope  Block structure  Visibility Static vs. dynamic binding Declarations and definitions More about blocks The.
 Control Flow statements ◦ Selection statements ◦ Iteration statements ◦ Jump statements.
1 Chapter 11 © 1998 by Addison Wesley Longman, Inc The Concept of Abstraction - The concept of abstraction is fundamental in programming - Nearly.
Chapter 9 Separate Compilation and Namespaces. Copyright © 2005 Pearson Addison-Wesley. All rights reserved. Slide 2 Overview Separate Compilation (9.1)
Copyright © 2008 Pearson Addison-Wesley. All rights reserved. Chapter 12 Separate Compilation and Namespaces.
Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 12 Separate Compilation and Namespaces.
1 Structure of Compilers Lexical Analyzer (scanner) Modified Source Program Parser Tokens Semantic Analysis Syntactic Structure Optimizer Code Generator.
Chapter 10: Classes and Data Abstraction. Classes Object-oriented design (OOD): a problem solving methodology Objects: components of a solution Class:
Copyright © Curt Hill Flow of Control A Quick Overview.
Copyright © 2012 Pearson Education, Inc. Chapter 10 Advanced Topics.
 Description of Inheritance  Base Class Object  Subclass, Subtype, and Substitutability  Forms of Inheritance  Modifiers and Inheritance  The Benefits.
CSE 332: C++ Exceptions Motivation for C++ Exceptions Void Number:: operator/= (const double denom) { if (denom == 0.0) { // what to do here? } m_value.
Advanced Programming in C
Polymorphism (Ch 8) Scope (Ch 10) Who are you? What do you do now?
Data Types In Text: Chapter 6.
Names and Attributes Names are a key programming language feature
Type Checking, and Scopes
CS 326 Programming Languages, Concepts and Implementation
Scope, Visibility, and Lifetime
Lecture 15 (Notes by P. N. Hilfinger and R. Bodik)
6 Chapter Functions.
Binding Times Binding is an association between two things Examples:
Scope Rules and Storage Types
Programming Languages and Paradigms
The Three Attributes of an Identifier
Presentation transcript:

Chapter TenModern Programming Languages1 Scope

Chapter TenModern Programming Languages2 Reusing Names Scope is trivial when all names are unique But in modern languages, names are often reused over and over: How can this work? fun square n = n * n; fun double n = n + n; fun square a = a * a; fun double b = b + b;

Chapter TenModern Programming Languages3 Outline Definitions and scope Scoping with blocks Scoping with labeled namespaces Scoping with primitive namespaces Dynamic scoping Separate compilation

Chapter TenModern Programming Languages4 Definitions When there are different variables with the same name, there are different possible bindings for that name Scope of variables, type names, constant names, function names, etc. A definition is anything that establishes a possible binding for a name

Chapter TenModern Programming Languages5 Examples fun square n = n * n; fun square square = square * square; typedef struct { int i; float f; } mystruct; mystruct ms = {5, 3.0}; {int i = ms.i; int ms = i; } cout << ms.i;

Chapter TenModern Programming Languages6 Scope There may be more than one definition for a given name Each occurrence of the name (other than a definition) has to be bound according to one of its definitions An occurrence of a name is in the scope of a given definition of that name whenever that definition governs the binding for that occurrence

Chapter TenModern Programming Languages7 Examples Each occurrence must be bound using one of the definitions Which one? There are many different ways to solve this scoping problem - fun square square = square * square; val square = fn : int -> int - square 3; val it = 9 : int

Chapter TenModern Programming Languages8 Why Scope is Necessary Control access to specific bindings Information hiding - restrict access to only those bindings necessary Parnas Principles on Information Hiding  Implementer has only information necessary to complete module and nothing more. Has no knowledge of user module internals.  User has only information necessary to complete module and nothing more. Has no knowledge of implementation module internals.

Chapter TenModern Programming Languages9 Exercise 1 – C User & Implementer typedef struct { double s[10]; int top; } Stack; void initialize(Stack &stk){ stk.top = -1; } void push(Stack &stk, double e){ stk.s[++stk.top] = e; } double pop( Stack &stk) { return stk.s[stk.top--]; } void initialize(); void push(double e); double pop(); void main() { Stack A; initialize(A); push(A, 3.14); push(A, -13.0); A.top = 1; cout << pop(A); } 1.Indicate which of a) or b) define user and implementer parts. 2.Parnas principles are violated. Where and how? a) b)

Chapter TenModern Programming Languages10 Exercise 1 – C User & Implementer typedef struct { double s[10]; int top; } Stack; Stack stk; void initialize() { stk.top = -1; } void push(double e) { stk.s[++stk.top] = e; } double pop() { return stk.s[stk.top--]; } void initialize(); void push(double e); double pop(); void main() { initialize(); push(3.14); push(-13.0); cout << pop(); } Is this a better information hiding solution than the previous? Why or why not?

Chapter TenModern Programming Languages11 Exercise 1 – C++ User & Implementer class Stack { private: double s[10]; int top; public: Stack(); double pop(); void push( double e ); }; Stack::Stack() { top = -1; } double Stack::pop() { return s[top--]; } void Stack::push(double e){ s[ ++top ] = e; }; class Stack { public: Stack(); double pop(); void push( double e ); }; void main() { Stack *s1 = new Stack(); s1->push(3.14); s1->push(-13.0); cout pop(); } 1.What names are visible to the user above? 2.A better information hiding solution? Why or why not?

Chapter TenModern Programming Languages12 Exercise 1 – ML User & Implementer fun push x [] = [x] | push x L = x::L; fun pop (h::t) = t; fun top (h::t) = h; 1.val s = push 3 []; 2.val s = push ~13 s; 3.val s = pop s; 4.top s; ML discourages assignment (mutation) on existing bindings, so that: val s = 5; s = 6; result is false! This makes maintaining and altering the state of the stack, through push and pop, difficult. Better solutions will be discussed in Chapter 11. What is the result of each line below:

Chapter TenModern Programming Languages13 Outline Definitions and scope Scoping with blocks Scoping with labeled namespaces Scoping with primitive namespaces Dynamic scoping Separate compilation

Chapter TenModern Programming Languages14 Blocks A block is any language construct that contains definitions, and also contains the region of the program where those definitions apply let val x = 1; val y = 2; in x+y end {int x = 1; int y = 2; { cout << x+y;}

Chapter TenModern Programming Languages15 Different ML Blocks The let is just a scoping block: no other purpose A fun definition includes a block: Multiple alternatives have multiple blocks: Each rule in a match is a block: fun cube x = x*x*x; fun f (a::b::_) = a+b | f [a] = a | f [] = 0; case x of (a,0) => a | (_,b) => b let val x = 1 val y =2 in x+y end;

Chapter TenModern Programming Languages16 Java Blocks In Java and other C-like languages, you can combine statements into one compound statement using { and } A compound statement also serves as a scoping block: What is the effect above? int i; for(i=0; i<3; i++) { int i = i+i; System.out.println( i ); }

Chapter TenModern Programming Languages17 Nesting What happens if a block contains another block, and both have definitions of the same name? ML example: what is the value of n? C++: what is the value of n? let val n = 1 in let val n = 2 in n end end int n = 1; { int n = 2; cout << n; }

Chapter TenModern Programming Languages18 Classic Block Scope Rule The scope of a definition is the block containing that definition, from the point of definition to the end of the block, minus the scopes of any redefinitions of the same name in interior blocks That is ML’s rule; most statically scoped, block-structured languages use this or some minor variation

Chapter TenModern Programming Languages19 Example let val n = 1 in let val n = 2 in n end end Scope of this definition is A and B Scope of this definition is B A B

Chapter TenModern Programming Languages20 Example int n = 1; { int n = 2; cout << n; } Scope of this definition is A and B Scope of this definition is B A B

Chapter TenModern Programming Languages21 Outline Definitions and scope Scoping with blocks Scoping with labeled namespaces Scoping with primitive namespaces Dynamic scoping Separate compilation

Chapter TenModern Programming Languages22 Labeled Namespaces A labeled namespace is any language construct that contains definitions and a region of the program where those definitions apply, and also has a name that can be used to access those definitions from outside the construct ML has one called a structure…

Chapter TenModern Programming Languages23 ML Structures A little like a block: a can be used anywhere inside definition to the end But the definitions are also available outside by: structure Fred = struct val a = 1; fun f x = x + a; end; Fred.a; val it = 1 : int Fred.f 3; val it = 4 : int

Chapter TenModern Programming Languages24 ML Structures – STACK Example structure STACK = struct fun pop (h::t) = h; fun remove (h::t) = t; fun push h t = h::t; end; val s = STACK.push 3 [];is [3] val s = STACK.push 4 s; is [4,3] val s = STACK.remove s;is [3] STACK.pop s;is 3 pop, remove, push only accessible via STACK structure

Chapter TenModern Programming Languages25 Other Labeled Namespaces Namespaces that are just namespaces:  C++ namespace  Modula-3 module  Ada package  Java package Namespaces that serve other purposes too:  Class definitions in class-based object-oriented languages

Chapter TenModern Programming Languages26 Example The variables min and max would be visible within the rest of the class Also accessible from outside, as Month.min and Month.max Classes serve a different purpose too public class Month { public static int min = 1; public static int max = 12; … }

Chapter TenModern Programming Languages27 Namespace Advantages Two conflicting goals:  Use memorable, simple names like max  For globally accessible things, use uncommon names like maxSupplierBid, names that will not conflict with other parts of the program With namespaces, you can accomplish both:  Within the namespace, you can use max  From outside, SupplierBid.max

Chapter TenModern Programming Languages28 Namespace Refinement Most namespace constructs have some way to allow part of the namespace to be kept private Often a good information hiding technique Programs are more maintainable when scopes are small For example, abstract data types reveal a strict interface while hiding implementation details…

Chapter TenModern Programming Languages29 Two Approaches Languages, such as C++, the namespace specifies the visibility of its components Other languages, such as ML, a separate construct defines the interface to a namespace (a signature in ML). The STACK structure has the signature at right. And some languages, such as Ada and Java, combine the two approaches signature STACK = sig val pop : 'a list -> 'a val push : 'a -> 'a list -> 'a list val remove : 'a list -> 'a list end; structure STACK = struct fun pop (h::t) = h; fun remove (h::t)=t; fun push h t = h::t; end;

Chapter TenModern Programming Languages30 Example: An Abstract Data Type namespace dictionary contains private: a constant definition for initialSize a type definition for hashTable a function definition for hash a function definition for reallocate public: a function definition for create a function definition for insert a function definition for search a function definition for delete end namespace Interface definitions should be visible Implementation definitions should be hidden

Chapter TenModern Programming Languages31 Separate Interface interface dictionary contains a function type definition for create a function type definition for insert a function type definition for search a function type definition for delete end interface namespace myDictionary implements dictionary contains a constant definition for initialSize a type definition for hashTable a function definition for hash a function definition for reallocate a function definition for create a function definition for insert a function definition for search a function definition for delete end namespace

Chapter TenModern Programming Languages32 Outline Definitions and scope Scoping with blocks Scoping with labeled namespaces Scoping with primitive namespaces Dynamic scoping Separate compilation

Chapter TenModern Programming Languages33 Do Not Try This At Home It is legal to have a variable named int ML is not confused but you might be. You can even do this (ML understands that int*int is not a type here): val int = 3; val int = 3 : int fun f int = int*int; val f = fn : int -> int f 3; val it = 9 : int

Chapter TenModern Programming Languages34 Primitive Namespaces ML’s syntax keeps types and expressions separated ML always knows whether it is looking for a type or for something else There is a separate namespace for types fun f(int:int) = (int:int)*(int:int); These are in the namespace for types These are in the ordinary namespace

Chapter TenModern Programming Languages35 Primitive Namespaces Not explicitly created using the language (like primitive types) They are part of the language definition Some languages have several separate primitive namespaces Java: packages, types, methods, fields, and statement labels are in separate namespaces

Chapter TenModern Programming Languages36 Exercise 2 – Valid Java? class Reuse { Reuse Reuse; Reuse Reuse(Reuse Reuse) { Reuse: for(;;) if(Reuse.Reuse(Reuse) == Reuse) break Reuse; return Reuse; } } Reuse as a class, attribute, method, parameter, and label name. Is it valid?

Chapter TenModern Programming Languages37 Outline Definitions and scope Scoping with blocks Scoping with labeled namespaces Scoping with primitive namespaces Dynamic scoping Separate compilation

Chapter TenModern Programming Languages38 When Is Scoping Resolved? All scoping tools seen so far are static Answer the question (whether a given occurrence of a name is in the scope of a given definition) at compile time Some languages postpone the decision until runtime: dynamic scoping

Chapter TenModern Programming Languages39 Dynamic Scoping Each function has an environment of definition If a name that occurs in a function is not found in its environment, its caller’s environment is searched And if not found there, the search continues back through the chain of callers This generates a rather odd scope rule…

Chapter TenModern Programming Languages40 Classic Dynamic Scope Rule The scope of a definition is the function containing that definition, from the point of definition to the end of the function, along with any functions when they are called (even indirectly) from within that scope— minus the scopes of any redefinitions of the same name in those called functions

Chapter TenModern Programming Languages41 Static Versus Dynamic The non-local environment is accessed by a link that points from one environment back to its enclosing environment. Both specify scope holes—places where a scope does not reach because of redefinitions The static rule specifies regions of program text, so environment can be determined at compile time. The environment static link points to the enclosing text. The dynamic rule specifies runtime events that determine the enclosing environment. Generally, the dynamic link points to the environment of the calling function.

Chapter TenModern Programming Languages42 Example fun g x = let val inc = 1; fun f y = y+inc; fun h z = let val inc = 2; in f z end; in h x end; What is the value of g 5 using ML’s classic block static scope rule?

Chapter TenModern Programming Languages43 Block Scope (Static) fun g x = let val inc = 1; fun f y = y+inc; in h x end; With block scope, the reference to inc is bound to the previous definition in the same block. f ’s caller’s environment, h, is inaccessible. The definition of inc in accessible to f is g’s. g 5 = 6 in ML fun h z = let val inc = 2; in f z end;

Chapter TenModern Programming Languages44 Dynamic Scope fun g x = let val inc = 1; fun f y = y+inc; fun h z = let val inc = 2; in f z end; in h x end; Dynamic scope binds inc reference to the definition in the caller’s environment. Effect at right is function f executes in caller’s h environment. g 5 = 7 using dynamic scope fun g x = let val inc = 1; fun h z = let val inc = 2; fun f y = y+inc; in f z end; in h x end;

Chapter TenModern Programming Languages45 ML Static versus Dynamic Scope val vue = 2; fun twice f vue = f (f vue); fun f1 x = x * vue; twice f1 3; -> 12 statically scoped. twice f1 3; -> 27 dynamically scoped.

Chapter TenModern Programming Languages46 ML Static versus Dynamic Scope val vue = 2; fun twice f vue = f (f vue); fun f1 x = x * vue; twice f1 3;Dynamic val vue = 2; fun twice f vue = f (f vue); fun f1 x = x * vue; twice f1 3;Static

Chapter TenModern Programming Languages47 ML Static Scope Diagram vue twice f f1 vue 3 Env. twice f ( f vue) x 3 6 Env. x * vue f1twice f1 3; returns 12 2 val vue = 2; fun twice f vue = f (f vue); fun f1 x = x*vue ; twice f1 3; f1

Chapter TenModern Programming Languages48 ML Dynamic Scope Diagram vue twice f f1 vue 3 Env. twice f (f vue) f1 twice f1 3; returns 27 2 x 3 9 Env. x * vue val vue = 2; fun twice f vue = f (f vue); fun f1 x = x*vue ; 3 twice f1 3; f1

Chapter TenModern Programming Languages49 C Static versus Dynamic Scope int vue = 2; int twice (int f(int), int vue) { return f (f (vue)); } int f1( int x ) { return x * vue; } twice (f1, 3); -> 12 statically scoped. twice (f1, 3); -> 27 dynamically scoped.

Chapter TenModern Programming Languages50 C Static versus Dynamic Scope int vue = 2; int twice( int f(int), int vue) { return f (f (vue)); } int f1(int x) { return x * vue;} twice (f1, 3);Dynamic int vue = 2; int twice( int f(int), int vue) { return f (f (vue)); } int f1(int x) { return x * vue;} twice (f1, 3 );Static

Chapter TenModern Programming Languages51 C Static Scope Diagram vue twice f f1 vue 3 Env. twice f ( f (vue)) x 3 6 Env. x * vue f1 twice (f1, 3); returns 12 2 int vue = 2; int twice(int f(int), int vue) { return f(f(vue));} int f1(int x) { return x*vue ;} twice (f1, 3); f1

Chapter TenModern Programming Languages52 C Dynamic Scope Diagram vue twice f f1 vue 3 Env. twice f (f (vue)) f1 twice (f1, 3); returns 27 2 x 3 9 Env. x * vue 3 twice (f1, 3); f1 int vue = 2; int twice(int f(int), int vue) { return f(f(vue));} int f1(int x) { return x*vue ;}

Chapter TenModern Programming Languages53 Exercise 3 1. Give the static scoping diagram. 2. What is the result with static scoping? 3. Give the dynamic scoping diagram. 4. What is the result with dynamic scope? int vue = 4; int twice ( int f(int), int vue) { return f (f(vue)); } int f1(int x) { return x*vue; } void main() { cout << twice( f1, 5); }

Chapter TenModern Programming Languages54 Where It Arises Only in a few languages: some dialects of Lisp and APL Available as an option in Common Lisp Drawbacks:  Difficult to implement efficiently  Creates large and complicated scopes, since scopes extend into called functions  Choice of variable name in caller can affect behavior of called function

Chapter TenModern Programming Languages55 Outline Definitions and scope Scoping with blocks Scoping with labeled namespaces Scoping with primitive namespaces Dynamic scoping Separate compilation

Chapter TenModern Programming Languages56 Separate Compilation Common to the classical sequence of language system steps used by C++, Fortran Parts are compiled separately, then linked together Scope issues extend to the linker: it needs to connect references to definitions across separate compilations Many languages have special support for this

Chapter TenModern Programming Languages57 C Approach, Compiler Side Two different kinds of definitions:  Full definition full.cpp  Name and type only: a declaration in C declaration.cpp Several files use same integer variable x :  Only one will have the full definition, int x = 3;  All others have the declaration extern int x; #include extern int x; void main(void) { cout << x; } int x = 3;

Chapter TenModern Programming Languages58 C Approach, Linker Side When the linker runs, it treats a declaration as a reference to a name defined in some other file It expects to see exactly one full definition of that name Note that the declaration does not say where to find the definition—it just requires the linker to find it somewhere Using Microsoft Visual C++ to compile and link files full.cpp and declaration.cpp to executable full.exe: cl full.cpp declaration.cpp

Chapter TenModern Programming Languages59 Older Fortran Approach, Compiler Side Older Fortran dialects used COMMON blocks All separate compilations define variables in the normal way All separate compilations give the same COMMON declaration: COMMON A,B,C

Chapter TenModern Programming Languages60 Older Fortran Approach, Linker Side The linker allocates just one block of memory for the COMMON variables: those from one compilation start at the same address as those from other compilations The linker does not use the local names If there is a COMMON A,B,C in one compilation and a COMMON X,Y,Z in another, A will be identified with X, B with Y, and C with Z

Chapter TenModern Programming Languages61 Modern Fortran Approach A MODULE can define data in one separate compilation A USE statement can import those definitions into another compilation USE says what module to use, but does not say what the definitions are So unlike the C approach, the Fortran compiler must at least look at the result of that separate compilation

Chapter TenModern Programming Languages62 Trends in Separate Compilation In recent languages, separate compilation is less separate than it used to be  Java classes can depend on each other circularly, so the Java compiler must be able to compile separate classes simultaneously  ML is not really suitable for separate compilation at all, though CM (a separate tool in the SML system, the Compilation Manager) can do it for most ML programs

Chapter TenModern Programming Languages63 Conclusion Today: four approaches for scoping  Scoping with blocks  Scoping with labeled namespaces  Scoping with primitive namespaces  Dynamic scoping There are many variations, and most languages employ several at once Remember: names do not have scopes, definitions do!