Programming Languages 1. Introduction. Oscar Nierstrasz

Similar documents
Com S 541. Programming Languages I

Language Translation, History. CS152. Chris Pollett. Sep. 3, 2008.

General Concepts. Abstraction Computational Paradigms Implementation Application Domains Influence on Success Influences on Design

Introduction. A. Bellaachia Page: 1

3. Functional Programming. Oscar Nierstrasz

8/27/17. CS-3304 Introduction. What will you learn? Semester Outline. Websites INTRODUCTION TO PROGRAMMING LANGUAGES

Topic I. Introduction and motivation References: Chapter 1 of Concepts in programming languages by J. C. Mitchell. CUP, 2003.

Chapter 2. 5 * B => A V 6 7 (subscripts) S 1.n 1.n (data types)

Programming Languages, Summary CSC419; Odelia Schwartz

Concepts in Programming Languages

2. Evolution of the Major Programming languages

COSC 2P90 Programming Languages & Object-Orientation

Principles in Programming: Orientation & Lecture 1. SWE2004: Principles in Programming Spring 2014 Euiseong Seo

Lecture 09. Ada to Software Engineering. Mr. Mubashir Ali Lecturer (Dept. of Computer Science)

Chapter 2. Pseudocodes: Speedcoding. 2.2 Minimal Hardware Programming: Pseudocodes. Evolution of the Major Programming Languages

7. Introduction to Denotational Semantics. Oscar Nierstrasz

Programming Languages (CS )

Introduction. chapter Functions

5. Introduction to the Lambda Calculus. Oscar Nierstrasz

Principles in Programming: Orientation & Lecture 1. SWE2004: Principles in Programming Spring 2015 Euiseong Seo

1. true / false By a compiler we mean a program that translates to code that will run natively on some machine.

Chapter 2 Preview. Preview. History of Programming Languages. History of Programming Languages. History of Programming Languages

Concepts of Programming Languages

Continuations provide a novel way to suspend and reexecute

Comp 333: Concepts of Programming Languages Fall 2016

CSc 520. Course Outline (Subject to change) Course Outline (Subject to change)... Principles of Programming Languages. Christian Collberg

Programming Language Concepts 1982, 1987, Outline. Period

Chapter 2. Evolution of the Major Programming Languages

CS A331 Programming Language Concepts

CSC 326H1F, Fall Programming Languages. What languages do you know? Instructor: Ali Juma. A survey of counted loops: FORTRAN

Evolution of PL s. EECS 476, Prog. Lang. Design/ page 1

8/23/18. Programming Language Genealogy The Evolution of Programming Languages. Zuse s Plankalkül. Plankalkül Syntax. Machine Code

Objective: To learn meaning and concepts of programming. Outcome: By the end of this students should be able to describe the meaning of programming

Functional Programming. Big Picture. Design of Programming Languages

Chapter 2. Chapter 2

CSCI.4430/6969 Programming Languages Lecture Notes

Logic Programming II & Revision

Chapter 2. Evolution of the Major Programming Languages ISBN

Introduction to Computer Science I

CS508-Modern Programming Solved MCQ(S) From Midterm Papers (1 TO 22 Lectures) BY Arslan

Programming Languages (CS )

1/14/2014. Introduction to CSE 1325 Object Oriented Programming (Using Java) Introduction (Cont.) Introduction

What is programming? Elements of Programming Languages. From machine code to programming languages. What is a programming language?

CS 565: Programming Languages. Spring 2008 Tu, Th: 16:30-17:45 Room LWSN 1106

Evolution of the Major Programming Languages

Chapter 2. Evolution of the Major Programming Languages ISBN

Chapter 2 Evolution of the Major Programming Languages Chapter 2 Topics

Chapter 2. Evolution of the Major Programming Languages

! Broaden your language horizons! Different programming languages! Different language features and tradeoffs. ! Study how languages are implemented

Compilation I. Hwansoo Han

Chapter 1. Preliminaries

Languages october 22, 2017 Éric Lévénez < FORTRAN III end-1958 FORTRAN II FORTRAN I october 1956

Programming Languages 2nd edition Tucker and Noonan"

Chapter 1. Preliminaries

Discovering Computers 2008

Programming Language Concepts

Chapter 1. Preview. Reason for Studying OPL. Language Evaluation Criteria. Programming Domains

Introduction to Scientific Computing Languages

Outline. Programming Languages 1/16/18 PROGRAMMING LANGUAGE FOUNDATIONS AND HISTORY. Current

! Broaden your language horizons. ! Study how languages are implemented. ! Study how languages are described / specified

Question No: 1 ( Marks: 1 ) - Please choose one One difference LISP and PROLOG is. AI Puzzle Game All f the given

Low-Level Languages. Computer Programs and Programming Languages

What is a programming language?

Programming Languages CMSC 4023 Chapter 2

CS 415 Midterm Exam Spring 2002

A Tour of Language Implementation

Introduction to Scientific Computing Languages

Seminar in Programming Languages

CSc 372. Comparative Programming Languages. 2 : Functional Programming. Department of Computer Science University of Arizona

Functional Programming Language Haskell

Organization of Programming Languages (CSE452) Why are there so many programming languages? What makes a language successful?

SOFTWARE ARCHITECTURE 6. LISP

Why are there so many programming languages? Why do we have programming languages? What is a language for? What makes a language successful?

Compilation 2012 The What and Why of Compilers

G Programming Languages - Fall 2012

Programming Languages (CSCI 4430/6430) History, Syntax, Semantics, Essentials, Paradigms

G Programming Languages Spring 2010 Lecture 1. Robert Grimm, New York University

G Programming Languages - Fall 2012

Programming Languages and Program Development Life Cycle Fall Introduction to Information and Communication Technologies CSD 102

CS383 PROGRAMMING LANGUAGES. Kenny Q. Zhu Dept. of Computer Science Shanghai Jiao Tong University

Thanks! Review. Course Goals. General Themes in this Course. There are many programming languages. Teaching Assistants. John Mitchell.

CSE 307: Principles of Programming Languages

CS 242. Fundamentals. Reading: See last slide

Lecture 1: Course Introduction

CSCI 3136 Principles of Programming Languages

CSCE 314 TAMU Fall CSCE 314: Programming Languages Dr. Flemming Andersen. Haskell Basics

Functional Programming

Which of the following is not true of FORTRAN?

Programming Paradigms

Informal Semantics of Data. semantic specification names (identifiers) attributes binding declarations scope rules visibility

Final-Term Papers Solved MCQS with Reference

Programming Languages and Program Development

Introduction P L COS 301. Fall School of Computing and Information Science University of Maine. Introduction COS 301.

CMPUT Language Paradigms. Programming Paradigms. Dr. B. Price & Dr. R. Greiner. 7th September Real languages draw upon multiple paradigms

Chapter 1 Preliminaries

MIDTERM EXAMINATION - CS130 - Spring 2005

St. MARTIN S ENGINEERING COLLEGE Dhulapally, Secunderabad

Lecture 1: Course Introduction

What Is Computer Science? The Scientific Study of Computation. Expressing or Describing

CSc 372 Comparative Programming Languages

Transcription:

Programming Languages 1. Introduction Oscar Nierstrasz

Roadmap > Course Schedule > Programming Paradigms > A Quick Tour of Programming Language History

Programming Languages Lecturer: Assistants: WWW: Oscar Nierstrasz Nevena Milojković-Lazarević, Manuel Leuenberger, Mohammadreza Hazhirpasand http://scg.unibe.ch/teaching/pl 3

Roadmap > Course Schedule > Programming Paradigms > A Quick Tour of Programming Language History

Sources > Text: Kenneth C. Louden, Programming Languages: Principles and Practice, PWS Publishing (Boston), 1993. > Other Sources: Paul Hudak, Conception, Evolution, and Application of Functional Programming Languages, ACM Computing Surveys 21/3, 1989, pp 359-411. Clocksin and Mellish, Programming in Prolog, Springer Verlag, 1987. 5

Schedule 1 23-Feb-18 Introduction 2 02-Mar-18 Stack-based Programming 3 09-Mar-18 Functional Programming 4 16-Mar-18 Types and Polymorphism 5 23-Mar-18 Lambda Calculus - 30-Mar-18 Good Friday - 06-Apr-18 Easter vacation 6 13-Apr-18 Fixed Points 7 20-Apr-18 Programming Language Semantics 8 27-Apr-18 Objects and Prototypes 9 04-May-18 Objects and Types 10 11-May-18 Logic Programming 11 18-May-18 Applications of Logic Programming 12 25-May-18 Visual Programming - 01-Jun-18 Final Exam 6

This is a note (a hidden slide). You will find some of these scattered around the PDF versions of the slides.

Roadmap > Course Schedule > Programming Paradigms > A Quick Tour of Programming Language History

What is a Programming Language? > A formal language for describing computation? > A user interface to a computer? > Syntax + semantics? > Compiler, or interpreter, or translator? > A tool to support a programming paradigm? A programming language is a notational system for describing computation in a machine-readable and human-readable form. Louden 9

What is a Programming Language? (II) The thesis of this course: A programming language is a tool for developing executable models for a class of problem domains. 10

Themes Addressed in this Course Paradigms How do different language paradigms support problem-solving? Foundations What are the foundations of programming languages? Semantics How can we understand the semantics of programming languages? 11

Generations of Programming Languages 1GL: 2GL: 3GL: 4GL: 5GL: machine codes symbolic assemblers (machine-independent) imperative languages domain specific application generators AI languages Each generation is at a higher level of abstraction 12

How do Programming Languages Differ? > Common Constructs: basic data types (numbers, etc.); variables; expressions; statements; keywords; control constructs; procedures; comments; errors... > Uncommon Constructs: type declarations; special types (strings, arrays, matrices,...); sequential execution; concurrency constructs; packages/modules; objects; general functions; generics; modifiable state;... 13

Programming Paradigms A programming language is a problem-solving tool. Imperative style: Functional style: Logic programming style: Object-oriented style: program = algorithms + data good for decomposition program = functions o functions good for reasoning program = facts + rules good for searching program = objects + messages good for modeling(!) Other styles and paradigms: blackboard, pipes and filters, constraints, lists,... 14

Compilers and Interpreters Pre-processor Parser Code Generator Assembler Program Parse tree / IR Assembly code Machine code Translator Interpreter Bytecode Generator JIT Compiler Program... Bytecode Compilers and interpreters have similar front-ends, but have different back-ends. Bytecode Interpreter 15

Roadmap > Course Schedule > Programming Paradigms > A Quick Tour of Programming Language History

A Brief Chronology Early 1950s order codes (primitive assemblers) 1957 FORTRAN the first high-level programming language 1958 ALGOL the first modern, imperative language 1960 LISP, COBOL Interactive programming; business programming 1962 APL, SIMULA the birth of OOP (SIMULA) 1964 BASIC, PL/I 1966 ISWIM first modern functional language (a proposal) 1970 Prolog logic programming is born 1972 C the systems programming language 1975 Pascal, Scheme two teaching languages 1978 CSP Concurrency matures 1978 FP Backus proposal 1983 Smalltalk-80, Ada OOP is reinvented 1984 Standard ML FP becomes mainstream (?) 1986 C++, Eiffel OOP is reinvented (again) 1988 CLOS, Oberon, Mathematica 1990 Haskell FP is reinvented 1990s Perl, Python, Ruby, JavaScript Scripting languages become mainstream 1995 Java OOP is reinvented for the internet 2000 C# 17

Fortran History > John Backus (1953) sought to write programs in conventional mathematical notation, and generate code comparable to good assembly programs. > No language design effort (made it up as they went along) > Most effort spent on code generation and optimization > FORTRAN I released April 1957; working by April 1958 > The current standard is FORTRAN 2008 (FORTRAN 2015 is work in progress) 18

Fortran Innovations > Symbolic notation for subroutines and functions > Assignments to variables of complex expressions > DO loops > Comments > Input/output formats > Machine-independence Successes > Easy to learn; high level > Promoted by IBM; addressed large user base > (scientific computing) 19

Hello World in FORTRAN PROGRAM HELLO DO 10, I=1,10 PRINT *,'Hello World' 10 CONTINUE STOP END All examples from the ACM "Hello World" project: www2.latech.edu/~acm/helloworld.shtml 20

ALGOL 60 History > Committee of PL experts formed in 1955 to design universal, machine-independent, algorithmic language > First version (ALGOL 58) never implemented; criticisms led to ALGOL 60 Innovations > BNF (Backus-Naur Form) introduced to define syntax (led to syntaxdirected compilers) > First block-structured language; variables with local scope > Structured control statements > Recursive procedures > Variable size arrays Successes > Highly influenced design of other PLs but never displaced FORTRAN 21

Hello World in BEALGOL BEGIN FILE F (KIND=REMOTE); EBCDIC ARRAY E [0:11]; REPLACE E BY "HELLO WORLD!"; WHILE TRUE DO BEGIN WRITE (F, *, E); END; END. 22

COBOL History > Designed by committee of US computer manufacturers > Targeted business applications > Intended to be readable by managers (!) Innovations > Separate descriptions of environment, data, and processes Successes > Adopted as de facto standard by US DOD > Stable standard for 25 years > Still the most widely used PL for business applications (!) 23

Hello World in COBOL 000100 IDENTIFICATION DIVISION. 000200 PROGRAM-ID. HELLOWORLD. 000300 DATE-WRITTEN. 02/05/96 21:04. 000400* AUTHOR BRIAN COLLINS 000500 ENVIRONMENT DIVISION. 000600 CONFIGURATION SECTION. 000700 SOURCE-COMPUTER. RM-COBOL. 000800 OBJECT-COMPUTER. RM-COBOL. 001000 DATA DIVISION. 001100 FILE SECTION. 100000 PROCEDURE DIVISION. 100200 MAIN-LOGIC SECTION. 100300 BEGIN. 100400 DISPLAY " " LINE 1 POSITION 1 ERASE EOS. 100500 DISPLAY "HELLO, WORLD." LINE 15 POSITION 10. 100600 STOP RUN. 100700 MAIN-LOGIC-EXIT. 100800 EXIT. 24

PL/1 History > Designed by committee of IBM and users (early 1960s) > Intended as (large) general-purpose language for broad classes of applications Innovations > Support for concurrency (but not synchronization) > Exception-handling on conditions Successes > Achieved both run-time efficiency and flexibility (at expense of complexity) > First complete general purpose language 25

Hello World in PL/1 HELLO: PROCEDURE OPTIONS (MAIN); /* A PROGRAM TO OUTPUT HELLO WORLD */ FLAG = 0; LOOP: DO WHILE (FLAG = 0); PUT SKIP DATA('HELLO WORLD!'); END LOOP; END HELLO; 26

Functional Languages > ISWIM (If you See What I Mean) Peter Landin (1966) paper proposal > FP John Backus (1978) Turing award lecture > ML Edinburgh initially designed as meta-language for theorem proving Hindley-Milner type inference non-pure functional language (with assignments/side effects) > Miranda, Haskell pure functional languages with lazy evaluation 27

Hello World in Functional Languages SML print("hello world!\n"); Haskell hello() = print "Hello World" 28

Prolog History > Originated at U. Marseilles (early 1970s), and compilers developed at Marseilles and Edinburgh (mid to late 1970s) Innovations > Theorem proving paradigm > Programs as sets of clauses: facts, rules and questions > Computation by unification Successes > Prototypical logic programming language > Used in Japanese Fifth Generation Initiative 29

Hello World in Prolog hello :- printstring("hello WORLD!!!!"). printstring([]). printstring([h T]) :- put(h), printstring(t). 30

Object-Oriented Languages History > Simula was developed by Nygaard and Dahl (early 1960s) in Oslo as a language for simulation programming, by adding classes and inheritance to ALGOL 60 Begin while 1 = 1 do begin outtext ("Hello World!"); outimage; end; End; > Smalltalk was developed by Xerox PARC (early 1970s) to drive graphic workstations Transcript show:'hello World';cr 31

Object-Oriented Languages Innovations > Encapsulation of data and operations (contrast ADTs) > Inheritance to share behaviour and interfaces Successes > Smalltalk project pioneered OO user interfaces > Large commercial impact since mid 1980s > Countless new languages: C++, Objective C, Eiffel, Beta, Oberon, Self, Perl 5, Python, Java, Ada 95... 32

Interactive Languages > Made possible by advent of time-sharing systems (early 1960s through mid 1970s). BASIC > Developed at Dartmouth College in mid 1960s > Minimal; easy to learn > Incorporated basic O/S commands (NEW, LIST, DELETE, RUN, SAVE) >... 10 print "Hello World!" 20 goto 10 33

Interactive Languages... APL > Developed by Ken Iverson for concise description of numerical algorithms > Large, non-standard alphabet (52 characters in addition to alphanumerics) > Primitive objects are arrays (lists, tables or matrices) > Operator-driven (power comes from composing array operators) > No operator precedence (statements parsed right to left) 'HELLO WORLD' 34

Special-Purpose Languages SNOBOL > First successful string manipulation language > Influenced design of text editors more than other PLs > String operations: pattern-matching and substitution > Arrays and associative arrays (tables) > Variable-length strings >... END OUTPUT = 'Hello World!' 35

Symbolic Languages... Lisp > Performs computations on symbolic expressions > Symbolic expressions are represented as lists > Small set of constructor/selector operations to create and manipulate lists > Recursive rather than iterative control > No distinction between data and programs > First PL to implement storage management by garbage collection > Affinity with lambda calculus (DEFUN HELLO-WORLD () (PRINT (LIST 'HELLO 'WORLD))) 36

4GLs Problem-oriented languages > PLs for non-programmers > Very High Level (VHL) languages for specific problem domains Classes of 4GLs (no clear boundaries) > Report Program Generator (RPG) > Application generators Query languages > Decision-support languages > Successes > Highly popular, but generally ad hoc 37

Hello World in RPG H FSCREEN O F 80 80 C EXCPT OSCREEN E 1 O CRT 12 'HELLO WORLD!' 38

Hello World in SQL CREATE TABLE HELLO (HELLO CHAR(12)) UPDATE HELLO SET HELLO = 'HELLO WORLD!' SELECT * FROM HELLO 39

Scripting Languages History Countless shell languages and command languages for operating systems and configurable applications Unix shell (ca. 1971) developed as user shell and scripting tool HyperTalk (1987) was developed at Apple to script HyperCard stacks TCL (1990) developed as embedding language and scripting language for X windows applications (via Tk) echo "Hello, World!" on OpenStack show message box put "Hello World!" into message box end OpenStack puts "Hello World " Perl (~1990) became de facto web scripting language print "Hello, World!\n"; 40

Scripting Languages... Innovations > Pipes and filters (Unix shell) > Generalized embedding/command languages (TCL) Successes > Unix Shell, awk, emacs, HyperTalk, AppleTalk, TCL, Python, Perl, VisualBasic... 41

The future? > Dynamic languages very active > Domain-specific languages very active > Visual languages many developments, but still immature > Modeling languages emerging from UML and MDE 42

What you should know! > What, exactly, is a programming language? > How do compilers and interpreters differ? > Why was FORTRAN developed? > What were the main achievements of ALGOL 60? > Why do we call C a Third Generation Language? > What is a Fourth Generation Language? 43

Can you answer these questions? > Why are there so many programming languages? > Why are FORTRAN and COBOL still important programming languages? > Which language should you use to implement a spelling checker? > A filter to translate upper-to-lower case? > A theorem prover? > An address database? > An expert system? > A game server for initiating chess games on the internet? > A user interface for a network chess client? 44

Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) You are free to: Share copy and redistribute the material in any medium or format Adapt remix, transform, and build upon the material for any purpose, even commercially. The licensor cannot revoke these freedoms as long as you follow the license terms. Under the following terms: Attribution You must give appropriate credit, provide a link to the license, and indicate if changes were made. You may do so in any reasonable manner, but not in any way that suggests the licensor endorses you or your use. ShareAlike If you remix, transform, or build upon the material, you must distribute your contributions under the same license as the original. No additional restrictions You may not apply legal terms or technological measures that legally restrict others from doing anything the license permits. http://creativecommons.org/licenses/by-sa/4.0/