History of programming languages and tools


Информатика, кибернетика и программирование

History of progrmming lnguges nd tools. PreHistory The first progrmming lnguges predte the modern computer. Figure 1 Punch crd Like mny firsts in history the first modern progrmming lnguge is hrd to identify. To some people the nswer depends on how much power nd humnredbility is required before the sttus of ldquo;progrmming lngugerdquo; is grnted.



242.5 KB

3 чел.

Lecture 1. History of programming languages and tools.11

  1.  Pre-History

The first programming languages predate the modern computer. From the first, the languages were codes. Herman Hollerith ((1860 – 1929) American statistician and inventor) realized that he could encode information on punch cards when he observed that railroad train conductors would encode the appearance of the ticket holders on the train tickets using the position of punched holes on the tickets. Hollerith then proceeded to encode the 1890 census data on punch cards which he made the same size as the boxes for holding US currency (refer to Figure 1). (The dollar bill was later downsized.)

Figure 1 - Punch card

Like many “firsts” in history, the first modern programming language is hard to identify. From the start, the restrictions of the hardware defined the language. Punch cards allowed 80 columns, but some of the columns had to be used for a sorting number on each card. FORTRAN included some keywords which were the same as English words, such as “IF”, “GOTO” and “CONTINUE”. The use of a magnetic drum for memory meant that computer programs also had to be interleaved with the rotations of the drum. Thus the programs were more hardware dependent than today.

To some people the answer depends on how much power and human-readability is required before the status of “programming language” is granted. Jacquard looms and Charles Babbage’s Difference Engine both had simple, extremely limited languages for describing the actions that these machines should perform. One can even regard the punch holes on a player piano scroll as a limited domain-specific programming language (refer to Figure 2), albeit not designed for human consumption.

Figure 2 - Piano scroll and its use

1.2 The 1940s

In the 1940s the first recognizably modern, electrically powered computers were created. The limited speed and memory capacity forced programmers to write hand tuned assembly language programs. It was soon discovered that programming in assembly language required a great deal of intellectual effort and was error-prone.

In 1945, Konrad Zuse published details of his programming language Plankalkül. However, it was not implemented in his time and his original contributions were isolated from other developments because Germany was isolated during the war.

Some important languages that were developed in this time period include:

•1943 - Plankalkül (Konrad Zuse)

•1943 - ENIAC coding system

•1949 - C-10

1.3 The 1950s and 1960s

In the 1950s the first three modern programming languages whose descendants are still in widespread use today were designed:

  •  FORTRAN, the “FORmula TRANslator”, invented by John W. Backus et al.;
  •  LISP, the “LISt Processor”, invented by John McCarthy et al.;
  •  COBOL, the COmmon Business Oriented Language, created by the Short Range Committee, heavily influenced by Grace Hopper.

Another milestone in the late 1950s was the publication, by a committee of American and European computer scientists, of “a new language for algorithms”; the Algol 60 Report (the “ALGOrithmic Language”). This report consolidated many ideas circulating at the time and featured two key innovations:

  •  The use of Backus-Naur Form (BNF) for describing the language’s syntax. Nearly all subsequent programming languages have used a variant of BNF to describe the context-free portion of their syntax.
  •  The introduction of lexical scoping for names in arbitrarily nested scopes.

Algol 60 was particularly influential in the design of later languages, some of which soon became more popular. The Burroughs B5000 was designed to be programmed in an extended subset of Algol.

Some important languages that were developed in this time period include:

  •  1951 - Regional Assembly Language
  •  1952 - Autocode
  •  1954 - FORTRAN (released commercially in 1957)
  •  1958 - LISP
  •  1958 - ALGOL
  •  1959 - COBOL
  •  1962 - APL
  •  1962 - Simula
  •  1964 - BASIC
  •  1964 - PL/I

1.4 1967-1978: establishing fundamental paradigms

The period from the late 1960s to the late 1970s brought a major flowering of programming languages. Most of the major language paradigms now in use were invented in this period:

  •  Simula, invented in the late 1960s by Nygaard and Dahl as a superset of Algol 60, was the first language designed to support object-oriented programming.
  •  Smalltalk (mid 1970s) provided a complete ground-up design of an object-oriented language.
  •  C, an early systems programming language, was developed by Dennis Ritchie and Ken Thompson at Bell Labs between 1969 and 1973.
  •  Prolog, designed in 1972 by Colmerauer, Roussel, and Kowalski, was the first logic programming language.
  •  ML built a polymorphic type system (invented by Robin Milner in 1978) on top of Lisp, pioneering statically typed functional programming languages.

Each of these languages spawned an entire family of descendants, and most modern languages count at least one of them in their ancestry.

The 1960s and 1970s also saw considerable debate over the merits of “structured programming”, which essentially meant programming without the use of GOTO. This debate was closely related to language design: some languages did not include GOTO, which forced structured programming on the programmer. Although the debate raged hotly at the time, nearly all programmers now agree that, even in languages that provide GOTO, it is bad style to use it except in rare circumstances. As a result, later generations of language designers have found the structured programming debate tedious and even bewildering.

Some important languages that were developed in this time period include:

  •  1970 - Pascal
  •  1972 - C
  •  1972 - Smalltalk
  •  1972 - Prolog
  •  1973 - ML
  •  1978 - SQL

1.5 The 1980s: consolidation, modules, performance

The 1980s were years of relative consolidation. C++ combined object-oriented and systems programming. The United States government standardized Ada, a systems programming language intended for use by defense contractors. In Japan and elsewhere, vast sums were spent investigating so-called “fifth generation” languages that incorporated logic programming constructs. The functional languages community moved to standardize ML and LISP. Rather than inventing new paradigms, all of these movements elaborated upon the ideas invented in the previous decade.

However, one important new trend in language design was an increased focus on programming for large-scale systems through the use of modules, or large-scale organizational units of code. Modula, Ada, and ML all developed notable module systems in the 1980s. Module systems were often wedded to generic programming constructs-generics being, in essence, parameterized modules.

Although major new paradigms for programming languages did not appear, many researchers expanded on the ideas of prior languages and adapted them to new contexts. For example, the languages of the Argus and Emerald systems adapted object-oriented programming to distributed systems.

The 1980s also brought advances in programming language implementation. The RISC movement in computer architecture postulated that hardware should be designed for compilers rather than for human assembly programmers. Aided by processor speed improvements that enabled increasingly aggressive compilation techniques, the RISC movement sparked greater interest in compilation technology for high-level languages.

Language technology continued along these lines well into the 1990s. However, the adoption of languages has always been driven by the adoption of new computer systems, and in the mid-1990s one of the most important new systems in computer history suddenly exploded in popularity.

Some important languages that were developed in this time period include:

  •  1983 - Ada
  •  1983 - C++
  •  1985 - Eiffel
  •  1987 - Perl
  •  1989 - FL (Backus)

1.6 The 1990s: the Internet age

The rapid growth of the Internet in the mid-1990s was the next major historic event in programming languages. By opening up a radically new platform for computer systems, the Internet created an opportunity for new languages to be adopted. In particular, the Java programming language rose to popularity because of its early integration with the Netscape Navigator web browser, and various scripting languages achieved widespread use in developing customized applications for web servers. Many computer information systems degree courses today teach Java as well as other programming languages. Neither of these developments represented much fundamental novelty in language design; for example, the design of Java was a more conservative version of ideas explored many years earlier in the Smalltalk community, but the widespread adoption of languages that supported features like garbage collection and strong static typing was a major change in programming practice.

Some important languages that were developed in this time period include:

  •  1990 - Haskell
  •  1990 - Python
  •  1991 - Java
  •  1993 - Ruby
  •  1994 - PHP
  •  2000 - C#

1 Material for this lecture was taken from http://www.computernostalgia.net/articles/HistoryofProgrammingLanguages.htm and http://www.scriptol.com/programming/history.php


А также другие работы, которые могут Вас заинтересовать

40835. Президенти Міжнародного олімпійського комітету 165 KB
  Президенти Міжнародного олімпійського комітету МОК План лекції 1. Президенти МОК: основні моменти біографії та вплив діяльності на зміни в олімпійському русі: Д. Відповідно до Олімпійської хартії затвердженої на цьому конгресі президент МОК мав представляти країну що проводить чергові Олімпійські ігри. Вікелас у віці 59 років був обраний першим президентом МОК.
40836. Соціально-політичні і правові аспекти сучасного олімпійського спорту 79 KB
  З підвищенням рівня популярності і міжнародної ваги Олімпійських ігор останні виявилися ареною суперництва не тільки самих спортсменів і навіть не тільки їх національних збірних але держав і груп держав за світове визнання і вплив. Одним з неминучих следствій що розвернулася і продовжувалася до цього дня навколо і усередині Олімпійських ігор міждержавної політичної боротьби стали і різні способи публічної демонстрації відношення до тих або інших держав або груп держав. Це може бути демонстративна відмова в ході підготовки і проведення...
40837. Менеджмент та оптимізація структури капіталу підприємства 106 KB
  Менеджмент та оптимізація структури капіталу підприємства 1. Особливості руху капіталу підприємства Під загальним поняттям капітал підприємства розуміють такі його види що характеризуються в даний час декількома десятками термінів. Розглянемо більш докладно окремі види капіталу підприємства відповідно до основних класифікаційних ознак. Ця частина активів сформована за рахунок інвестованого в них власного капіталу являє собою чисті активи підприємства.
40838. Значення і місце аеробіки в системі фізичного виховання 51.5 KB
  Значення і місце аеробіки в системі фізичного виховання. Особливості оздоровчої аеробіки як виду фізкультурноспортивної діяльності. Класифікація видів оздоровчої аеробіки. Особливості оздоровчої аеробіки як виду фізкультурноспортивної діяльності.
40839. Особливості проведення занять з оздоровчого фітнесу (базова аеробіка) 51 KB
  Розминка. Розминка має велике значення, але, на жаль її часто ігнорують, результатом чого є розтягування м'язів. В розминки дві мета: по-перше, розігріти м'язи спини і кінцівок; по-друге, викликати деяке прискорення темпу сердечних прискорень так, щоб плавно підвищувати пульс до значень, відповідних аеробній фазі.
40840. Активи як об’єкт фінансового менеджменту 105.5 KB
  Розглядаючи наведену формулу необхідно визначити період який потрібен для перетворення виробничих запасів дебіторської і кредиторської заборгованості в готівку.з середній період обороту дебіторської заборгованості; Ок.з середній строк сплати кредиторської заборгованості. Аналогічно визначається середній період обороту дебіторської заборгованості
40841. Основи адміністративного права України. Адміністративне правопорушення. Адміністративна відповідальність 34 KB
  Адміністративне правопорушення. Основним нормативним актом адміністративного права є Кодекс України про адміністративні правопорушення КпАП. Адміністративне правопорушення проступок це протиправна винна або необережна дія чи бездіяльність що посягає на державний або громадянський порядок власність права і свободи громадян на встановлений порядок управління за яку законодавством передбачена адміністративна відповідальність...
40842. Методы первого порядка (градиентные методы) 302.5 KB
  Соответствие методов и множеств. Методы решения переборных задач метод ветвей и границ динамическое программирование и др. Методы решения задач математического программирования условная безусловная минимизация нелинейное выпуклое и линейное программирование. Методы вариационного исчисления и методы оптимального управления уравнение ЭйлераЛагранжа принцип максимума.
40843. Методы прямого поиска в задачах одномерной минимизации 576 KB
  Найти минимум функции одной переменной нет анализа заданной функции. Больше ничего о функции неизвестно. Можно вычислить измерить значения функции в точках. После n nчетно экспериментов min функции лежит в интервале .