Open main menu
Home
Random
Recent changes
Special pages
Community portal
Preferences
About Wikipedia
Disclaimers
Incubator escapee wiki
Search
User menu
Talk
Dark mode
Contributions
Create account
Log in
Editing
Programming paradigm
Warning:
You are not logged in. Your IP address will be publicly visible if you make any edits. If you
log in
or
create an account
, your edits will be attributed to your username, along with other benefits.
Anti-spam check. Do
not
fill this in!
{{Short description|High-level computer programming conceptualization}} {{About|classification of programming languages|definition of the term "programming model"|Programming model}} A '''programming paradigm''' is a relatively high-level way to conceptualize and structure the implementation of a [[computer program]]. A [[programming language]] can be classified as supporting one or more paradigms.<ref>{{cite web |title=Multi-Paradigm Programming Language |url=https://developer.mozilla.org/en-US/docs/multiparadigmlanguage.html |website=Mozilla Developer Network |date= Jun 21, 2013 |publisher=[[Mozilla Foundation]] |archive-url=https://web.archive.org/web/20130821052407/https://developer.mozilla.org/en-US/docs/multiparadigmlanguage.html |archive-date=21 August 2013}}</ref> Paradigms are separated along and described by different dimensions of programming. Some paradigms are about implications of the [[execution model]], such as allowing [[Side effect (computer science)|side effects]], or whether the sequence of operations is defined by the execution model. Other paradigms are about the way code is organized, such as grouping into units that include both state and behavior. Yet others are about [[Syntax (programming languages)|syntax]] and [[Formal grammar|grammar]]. Some common programming paradigms include (shown in [[hierarchical relationship]]):<ref>NΓΈrmark, Kurt. ''[http://people.cs.aau.dk/~normark/prog3-03/html/notes/paradigms_themes-paradigm-overview-section.html Overview of the four main programming paradigms]''. Aalborg University, 9 May 2011. Retrieved 22 September 2012.</ref><ref>{{cite web |author=Frans Coenen |date=1999-10-11 |title=Characteristics of declarative programming languages |url=http://cgi.csc.liv.ac.uk/~frans/OldLectures/2CS24/declarative.html#detail |url-status=live |access-date=2014-02-20 |website=cgi.csc.liv.ac.uk |language=en-US|archive-date=2014-02-27|archive-url=https://web.archive.org/web/20140227142223/http://cgi.csc.liv.ac.uk/~frans/OldLectures/2CS24/declarative.html}}</ref><ref name="symbolic-programming-lisp">{{cite web |url = http://www.ai.uga.edu/mc/LispNotes/FirstLectureOnSymbolicProgramming.pdf |title = CSCI/ARTI 4540/6540: First Lecture on Symbolic Programming and LISP |date = 2010-08-23 |access-date = 2013-11-20 |author = Michael A. Covington |publisher = University of Georgia |archive-url = https://web.archive.org/web/20120307124013/http://www.ai.uga.edu/mc/LispNotes/FirstLectureOnSymbolicProgramming.pdf |archive-date = 2012-03-07 |url-status = dead }}</ref> * [[imperative programming|Imperative]] {{endash}} code directly controls [[Control flow|execution flow]] and state change, explicit statements that change a program state ** [[procedural programming|procedural]] {{endash}} organized as [[function (computer programming)|procedures]] that call each other ** [[object-oriented programming|object-oriented]] {{endash}} organized as [[Object (computer science)|objects]] that contain both data structure and associated behavior, uses data structures consisting of data fields and methods together with their interactions (objects) to design programs *** [[Class (computer programming)|Class-based]] β object-oriented programming in which inheritance is achieved by defining classes of objects, versus the objects themselves *** [[Prototype-based programming|Prototype-based]] β object-oriented programming that avoids classes and implements inheritance via cloning of instances * [[declarative programming|Declarative]] {{endash}} code declares properties of the desired result, but not how to compute it, describes what computation should perform, without specifying detailed state changes ** [[functional programming|functional]] {{endash}} a desired result is declared as the value of a series of function evaluations, uses evaluation of mathematical functions and avoids state and mutable data ** [[logic programming|logic]] {{endash}} a desired result is declared as the answer to a question about a system of facts and rules, uses explicit mathematical logic for programming ** [[Reactive programming|reactive]] {{endash}} a desired result is declared with data streams and the propagation of change *[[Concurrent programming language|Concurrent programming]] β has language constructs for concurrency, these may involve multi-threading, support for distributed computing, message passing, shared resources (including shared memory), or [[Futures and promises|futures]] **[[Actor model|Actor programming]] β concurrent computation with ''actors'' that make local decisions in response to the environment (capable of selfish or competitive behaviour) *[[Constraint programming]] β relations between variables are expressed as constraints (or constraint networks), directing allowable solutions (uses constraint satisfaction or [[simplex algorithm]]) *[[Dataflow|Dataflow programming]] β forced recalculation of formulas when data values change (e.g. [[Spreadsheet|spreadsheets]]) *[[Distributed computing|Distributed programming]] β has support for multiple autonomous computers that communicate via computer networks *[[Generic programming]] β uses algorithms written in terms of to-be-specified-later types that are then instantiated as needed for specific types provided as parameters *[[Metaprogramming]] β writing programs that write or manipulate other programs (or themselves) as their data, or that do part of the work at compile time that would otherwise be done at runtime **[[Template metaprogramming]] β metaprogramming methods in which a compiler uses templates to generate temporary source code, which is merged by the compiler with the rest of the source code and then compiled **[[Reflective programming]] β metaprogramming methods in which a program modifies or extends itself *[[Pipeline programming]] β a simple syntax change to add syntax to nest function calls to language originally designed with none *[[Rule-based programming]] β a network of rules of thumb that comprise a knowledge base and can be used for expert systems and problem deduction & resolution *[[Visual programming language|Visual programming]] β manipulating program elements graphically rather than by specifying them textually (e.g. [[Simulink]]); also termed ''diagrammatic programming' *[[Online presence management]] is distinct from [[Web presence management]] in that the former is generally a marketing and messaging discipline while the latter is [[Governance,risk management, and compliance]] operational and security discipline. == Overview == [[File:Programming paradigms.svg|thumb|250px|left|Overview of the various programming paradigms according to Peter Van Roy<ref>{{Cite web |url= http://www.info.ucl.ac.be/~pvr/VanRoyChapter.pdf |title= Programming Paradigms: What Every Programmer Should Know |date= 2009-05-12 |access-date= 2014-01-27 |author= Peter Van Roy |publisher= info.ucl.ac.be }}</ref>{{rp|5}}<ref name="Van-RoyHaridi2004">{{cite book|author1=Peter Van-Roy|author2=Seif Haridi|title=Concepts, Techniques, and Models of Computer Programming|url=https://books.google.com/books?id=_bmyEnUnfTsC|year=2004|publisher=MIT Press|isbn=978-0-262-22069-9}}</ref>]] Programming paradigms come from [[computer science]] [[research]] into existing practices of [[software development]]. The findings allow for describing and comparing programming practices and the languages used to code programs. For perspective, other fields of research study [[software engineering]] [[process]]es and describe various [[Methodology|methodologies]] to describe and compare them. A [[programming language]] can be described in terms of paradigms. Some languages support only one paradigm. For example, [[Smalltalk]] supports object-oriented and [[Haskell]] supports functional. Most languages support multiple paradigms. For example, a program written in [[C++]], [[Object Pascal]], or [[PHP]] can be purely [[Procedural programming|procedural]], purely [[Object-oriented programming|object-oriented]], or can contain aspects of both paradigms, or others. When using a language that supports multiple paradigms, the developer chooses which paradigm elements to use. But, this choice may not involve considering paradigms per se. The developer often uses the features of a language as the language provides them and to the extent that the developer knows them. Categorizing the resulting [[Source code|code]] by paradigm is often an academic activity done in retrospect. Languages categorized as '''imperative paradigm''' have two main features: they state the order in which operations occur, with constructs that explicitly control that order, and they allow side effects, in which state can be modified at one point in time, within one unit of code, and then later read at a different point in time inside a different unit of code. The communication between the units of code is not explicit. In contrast, languages in the '''declarative paradigm''' do not state the order in which to execute operations. Instead, they supply a number of available operations in the system, along with the conditions under which each is allowed to execute.<ref>{{Cite web |title=Programming paradigms: What are the principles of programming? |url=https://www.ionos.com/digitalguide/websites/web-development/programming-paradigms/ |url-status=live |access-date=2022-05-03 |website=IONOS Digitalguide |date=20 April 2020 |language=en-US |archive-url=https://web.archive.org/web/20220629200645/https://www.ionos.com/digitalguide/websites/web-development/programming-paradigms/ |archive-date=Jun 29, 2022}}</ref> The implementation of the language's execution model tracks which operations are free to execute and chooses the order independently. More at [[Comparison of multi-paradigm programming languages]]. In '''object-oriented''' programming, code is organized into [[Object (programming)|objects]] that contain state that is owned by and (usually) controlled by the code of the object. Most object-oriented languages are also imperative languages. In object-oriented programming, programs are treated as a set of interacting objects. In [[functional programming]], programs are treated as a sequence of stateless function evaluations. When programming computers or systems with many processors, in [[process-oriented programming]], programs are treated as sets of concurrent processes that act on a logical shared [[data structure]]s. Many programming paradigms are as well known for the techniques they ''forbid'' as for those they ''support''. For instance, pure functional programming disallows [[side-effect (computer science)|side-effects]], while [[structured programming]] disallows the [[goto]] construct. Partly for this reason, new paradigms are often regarded as doctrinaire or overly rigid by those accustomed to older ones.<ref name="rubin87goto">{{cite journal|author=Frank Rubin |date=March 1987 |url=http://www.ecn.purdue.edu/ParaMount/papers/rubin87goto.pdf |title='GOTO Considered Harmful' Considered Harmful |journal=Communications of the ACM |volume=30 |issue=3 |pages=195β196 |doi=10.1145/214748.315722 |s2cid=6853038 |url-status = dead|archive-url=https://web.archive.org/web/20090320002214/http://www.ecn.purdue.edu/ParaMount/papers/rubin87goto.pdf |archive-date=March 20, 2009}}</ref> Yet, avoiding certain techniques can make it easier to understand program behavior, and to [[Automated theorem proving|prove theorems]] about program correctness. Programming paradigms can also be compared with ''[[programming model]]s'', which allows invoking an [[execution model]] by using only an API. Programming models can also be classified into paradigms based on features of the execution model. For [[parallel computing]], using a programming model instead of a language is common. The reason is that details of the parallel hardware leak into the abstractions used to program the hardware. This causes the programmer to have to map patterns in the algorithm onto patterns in the execution model (which have been inserted due to leakage of hardware into the abstraction). As a consequence, no one parallel programming language maps well to all computation problems. Thus, it is more convenient to use a base sequential language and insert API calls to parallel execution models via a programming model. Such parallel programming models can be classified according to abstractions that reflect the hardware, such as [[shared memory]], [[distributed memory]] with [[message passing]], notions of ''place'' visible in the code, and so forth. These can be considered flavors of programming paradigm that apply to only parallel languages and programming models. == Criticism == Some programming language researchers criticise the notion of paradigms as a classification of programming languages, e.g. Harper,<ref>{{cite web|first=Robert|last=Harper|title=What, if anything, is a programming-paradigm?|url=http://www.cambridgeblog.org/2017/05/what-if-anything-is-a-programming-paradigm/|website = FifteenEightyFour|publisher = Cambridge University Press|date = 1 May 2017}}</ref> and Krishnamurthi.<ref>{{cite journal |first= Shriram |last= Krishnamurthi |publisher= ACM |url= http://dl.acm.org/citation.cfm?id=1480846 |title= Teaching programming languages in a post-linnaean age |journal= ACM SIGPLAN Notices |date= November 2008 |volume= 43 |issue= 11 |pages= 81β83|doi= 10.1145/1480828.1480846 |s2cid= 35714982 }}.</ref> They argue that many programming languages cannot be strictly classified into one paradigm, but rather include features from several paradigms. See [[Comparison of multi-paradigm programming languages]]. == History == Different approaches to programming have developed over time. Classification of each approach was either described at the time the approach was first developed, but often not until some time later, retrospectively. An early approach consciously identified as such is [[structured programming]], advocated since the mid 1960s. The concept of a ''programming paradigm'' as such dates at least to 1978, in the [[Turing Award]] lecture of [[Robert W. Floyd]], entitled ''The Paradigms of Programming'', which cites the notion of paradigm as used by [[Thomas Kuhn]] in his ''[[The Structure of Scientific Revolutions]]'' (1962).<ref>{{Cite journal |last1= Floyd |first1= R. W. |title= The paradigms of programming | doi= 10.1145/359138.359140 |journal= Communications of the ACM |volume= 22 |issue= 8 |pages= 455β460 |year= 1979 |doi-access= free }}</ref> Early programming languages did not have clearly defined programming paradigms and sometimes programs made extensive use of goto statements. Liberal use of which lead to [[spaghetti code]] which is difficult to understand and maintain. This led to the development of structured programming paradigms that disallowed the use of goto statements; only allowing the use of more structured programming constructs.<ref>{{cite book | url=https://books.google.com/books?id=POAplMgrk4wC&dq=programming+paradigm+structured&pg=PA20 | title=Java 5: Objects First | isbn=9780763737207 | last1=Soroka | first1=Barry I. | year=2006 | publisher=Jones & Bartlett Learning }}</ref> == Languages and paradigms == === Machine code === [[Machine code]] is the lowest-level of computer programming as it is [[Instruction set|machine instructions]] that define behavior at the lowest level of abstract possible for a computer. As it is the most prescriptive way to code it is classified as imperative. It is sometimes called the [[first-generation programming language]]. === Assembly === [[Assembly language]] introduced mnemonics for machine instructions and [[memory address]]es. Assembly is classified as imperative and is sometimes called the [[second-generation programming language]]. In the 1960s, assembly languages were developed to support library COPY and quite sophisticated conditional macro generation and preprocessing abilities, CALL to [[subroutine]], external variables and common sections (globals), enabling significant code re-use and isolation from hardware specifics via the use of logical operators such as READ/WRITE/GET/PUT. Assembly was, and still is, used for time-critical systems and often in [[embedded system]]s as it gives the most control of what the machine does. === Procedural languages === [[Procedural language]]s, also called the [[third-generation programming language]]s are the first described as [[high-level programming language|high-level languages]]. They support vocabulary related to the problem being solved. For example, * COmmon Business Oriented Language ([[COBOL]]){{snd}} uses terms like [[computer file|file]], [[move (command)|move]] and [[copy (command)|copy]]. * FORmula TRANslation ([[FORTRAN]]){{snd}} using [[mathematical]] language terminology, it was developed mainly for scientific and engineering problems. * ALGOrithmic Language ([[ALGOL]]){{snd}} focused on being an appropriate language to define [[algorithm]]s, while using mathematical language terminology, targeting scientific and engineering problems, just like FORTRAN. * Programming Language One ([[PL/I]]){{snd}} a hybrid commercial-scientific general purpose language supporting [[pointer (computer programming)|pointer]]s. * Beginners All purpose Symbolic Instruction Code ([[BASIC]]){{snd}} it was developed to enable more people to write programs. * [[C (programming language)|C]]{{snd}} a general-purpose programming language, initially developed by [[Dennis Ritchie]] between 1969 and 1973 at [[AT&T Bell Labs]]. These languages are classified as procedural paradigm. They directly control the step by step process that a computer program follows. The [[efficacy]] and [[algorithmic efficiency|efficiency]] of such a program is therefore highly dependent on the programmer's skill. === Object-oriented programming === {{Main|Object-oriented programming}} In attempt to improve on procedural languages, [[object-oriented programming]] (OOP) languages were created, such as [[Simula]], [[Smalltalk]], [[C++]], [[Eiffel (programming language)|Eiffel]], [[Python (programming language)|Python]], [[PHP]], [[Java (programming language)|Java]], and [[C Sharp (programming language)|C#]]. In these languages, [[data]] and methods to manipulate the data are in the same code unit called an [[object (computer science)|object]]. This [[Encapsulation (computer programming)|encapsulation]] ensures that the only way that an object can access data is via ''[[Method (computer programming)|methods]]'' of the object that contains the data. Thus, an object's inner workings may be changed without affecting code that uses the object. There is [[Object-oriented programming#Criticism|controversy]] raised by [[Alexander Stepanov]], [[Richard Stallman]]<ref>{{cite web|url=http://groups.google.com/group/comp.emacs.xemacs/browse_thread/thread/d0af257a2837640c/37f251537fafbb03?lnk=st&q=%22Richard+Stallman%22+oop&rnum=5&hl=en#37f251537fafbb03|title=Mode inheritance, cloning, hooks & OOP (Google Groups Discussion)}}</ref> and other programmers, concerning the efficacy of the OOP paradigm versus the procedural paradigm. The need for every object to have associative methods leads some skeptics to associate OOP with [[software bloat]]; an attempt to resolve this dilemma came through [[Polymorphism (computer science)|polymorphism]]. Although most OOP languages are third-generation, it is possible to create an object-oriented assembler language. [[High Level Assembly]] (HLA) is an example of this that fully supports advanced data types and object-oriented assembly language programming{{snd}} despite its early origins. Thus, differing programming paradigms can be seen rather like ''motivational [[meme]]s'' of their advocates, rather than necessarily representing progress from one level to the next.{{Citation needed|date=March 2018}} Precise comparisons of competing paradigms' efficacy are frequently made more difficult because of new and differing terminology applied to similar entities and processes together with numerous implementation distinctions across languages. === Declarative languages === A [[declarative programming]] program describes what the problem is, not how to solve it. The program is structured as a set of properties to find in the expected result, not as a procedure to follow. Given a database or a set of rules, the computer tries to find a solution matching all the desired properties. An archetype of a declarative language is the [[fourth-generation programming language|fourth generation language]] [[SQL]], and the family of functional languages and logic programming. [[Functional programming]] is a subset of declarative programming. Programs written using this paradigm use [[subroutine|functions]], blocks of code intended to behave like [[function (mathematics)|mathematical functions]]. Functional languages discourage changes in the value of variables through [[assignment (computer science)|assignment]], making a great deal of use of [[recursion (computer science)|recursion]] instead. The [[logic programming]] paradigm views computation as [[automated reasoning]] over a body of knowledge. Facts about the [[domain (software engineering)|problem domain]] are expressed as logic formulas, and programs are executed by applying [[inference rule]]s over them until an answer to the problem is found, or the set of formulas is proved inconsistent. === Other paradigms === [[Symbolic programming]] is a paradigm that describes programs able to manipulate formulas and program components as data.<ref name="symbolic-programming-lisp"/> Programs can thus effectively modify themselves, and appear to "learn", making them suited for applications such as [[artificial intelligence]], [[expert system]]s, [[natural-language processing]] and computer games. Languages that support this paradigm include [[Lisp (programming language)|Lisp]] and [[Prolog]].<ref>{{cite web |url=http://www.allbusiness.com/glossaries/symbolic-programming/4950308-1.html |title=Business glossary: Symbolic programming definition |access-date=2014-07-30 |website=allbusiness.com }}</ref> [[Differentiable programming]] structures programs so that they can be [[Differentiation (mathematics)|differentiated]] throughout, usually via [[automatic differentiation]].<ref>{{Citation|last1=Wang|first1=Fei|title=Backpropagation with Callbacks: Foundations for Efficient and Expressive Differentiable Programming|date=2018|url=http://papers.nips.cc/paper/8221-backpropagation-with-callbacks-foundations-for-efficient-and-expressive-differentiable-programming.pdf|work=Advances in Neural Information Processing Systems 31|pages=10201β10212|editor-last=Bengio|editor-first=S.|publisher=Curran Associates, Inc.|access-date=2019-02-13|last2=Decker|first2=James|last3=Wu|first3=Xilun|last4=Essertel|first4=Gregory|last5=Rompf|first5=Tiark|editor2-last=Wallach|editor2-first=H.|editor3-last=Larochelle|editor3-first=H.|editor4-last=Grauman|editor4-first=K.}}</ref><ref name="innes">{{Cite journal|last1=Innes|first1=Mike|date=2018|title=On Machine Learning and Programming Languages|url=http://www.sysml.cc/doc/37.pdf|journal=SysML Conference 2018|access-date=2019-02-13|archive-url=https://web.archive.org/web/20180920175619/http://www.sysml.cc/doc/37.pdf|archive-date=2018-09-20|url-status=dead}}</ref> [[Literate programming]], as a form of [[imperative programming]], structures programs as a human-centered web, as in a [[hypertext]] essay: documentation is integral to the program, and the program is structured following the logic of prose exposition, rather than compiler convenience. [[Symbolic programming]] techniques such as [[reflective programming]] (reflection), which allow a program to refer to itself, might also be considered as a programming paradigm. However, this is compatible with the major paradigms and thus is not a real paradigm in its own right. == See also == {{Portal|Computer programming}} {{div col}} * [[Domain-specific language]] * [[Flow-based programming]] * [[Modeling language]] * [[Programming domain]] * [[Turing completeness]] * [[Von Neumann programming languages]] {{div col end}} == References == {{Reflist}} ==External links== {{Commons category|Programming language by paradigm}} *[http://www.info.ucl.ac.be/~pvr/paradigms.html Classification of the principal programming paradigms] *[http://www.janeve.me/articles/understanding-programming-paradigms How programming paradigms evolve and get adopted?] {{Navboxes | title= Software engineering | state= collapsed | list= {{Computer language}} {{Software engineering}} {{Computer science}} }} {{Navboxes | title= Programming | state= collapsed | list= {{Programming paradigms navbox}} {{Programming language generations}} {{Major programming languages}} {{Types of programming languages}} }} {{Computer_science}} {{authority control}} {{DEFAULTSORT:Programming paradigm}} [[Category:Programming paradigms| ]] [[Category:Programming language classification]] [[Category:Programming language topics]]
Edit summary
(Briefly describe your changes)
By publishing changes, you agree to the
Terms of Use
, and you irrevocably agree to release your contribution under the
CC BY-SA 4.0 License
and the
GFDL
. You agree that a hyperlink or URL is sufficient attribution under the Creative Commons license.
Cancel
Editing help
(opens in new window)
Pages transcluded onto the current version of this page
(
help
)
:
Template:About
(
edit
)
Template:Authority control
(
edit
)
Template:Citation
(
edit
)
Template:Citation needed
(
edit
)
Template:Cite book
(
edit
)
Template:Cite journal
(
edit
)
Template:Cite web
(
edit
)
Template:Commons category
(
edit
)
Template:Computer science
(
edit
)
Template:Div col
(
edit
)
Template:Div col end
(
edit
)
Template:Endash
(
edit
)
Template:Main
(
edit
)
Template:Navboxes
(
edit
)
Template:Portal
(
edit
)
Template:Reflist
(
edit
)
Template:Rp
(
edit
)
Template:Short description
(
edit
)
Template:Snd
(
edit
)