Comparison of multi-paradigm programming languages explained
Programming languages can be grouped by the number and types of paradigms supported.
Paradigm summaries
A concise reference for the programming paradigms listed in this article.
- Concurrent programming – have language constructs for concurrency, these may involve multi-threading, support for distributed computing, message passing, shared resources (including shared memory), or futures
- 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 programming – forced recalculation of formulas when data values change (e.g. spreadsheets)
- Declarative programming – describes what computation should perform, without specifying detailed state changes c.f. imperative programming (functional and logic programming are major subgroups of declarative programming)
- Distributed programming – have support for multiple autonomous computers that communicate via computer networks
- Functional programming – uses evaluation of mathematical functions and avoids state and mutable data
- 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
- Imperative programming – explicit statements that change a program state
- Logic programming – uses explicit mathematical logic for programming
- 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
- Object-oriented programming – uses data structures consisting of data fields and methods together with their interactions (objects) to design programs
- Class-based – object-oriented programming in which inheritance is achieved by defining classes of objects, versus the objects themselves
- Prototype-based – object-oriented programming that avoids classes and implements inheritance via cloning of instances
- 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 – manipulating program elements graphically rather than by specifying them textually (e.g. Simulink); also termed diagrammatic programming[1]
Language overview
See also
References
- Jim Coplien, Multiparadigm Design for C++, Addison-Wesley Professional, 1998.
Notes and References
- Book: Bragg . S.D. . Driskill . C.G. . 20–22 September 1994 . Diagrammatic-graphical programming languages and DoD-STD-2167A . Institute of Electrical and Electronics Engineers (IEEE) . 10.1109/AUTEST.1994.381508 . Proceedings of AUTOTESTCON '94 (IEEEXplore) . 211–220 . 978-0-7803-1910-3 . 62509261.
- http://www.adaic.org/standards/05rm/html/RM-TTL.html Ada Reference Manual, ISO/IEC 8652:2005(E) Ed. 3
- http://www.adaic.org/standards/05rm/html/RM-TTL.html Ada Reference Manual, ISO/IEC 8652:2005(E) Ed. 3
- http://www.adaic.org/standards/05rm/html/RM-TTL.html Ada Reference Manual, ISO/IEC 8652:2005(E) Ed. 3
- http://www.adaic.org/standards/05rm/html/RM-TTL.html Ada Reference Manual, ISO/IEC 8652:2005(E) Ed. 3
- http://www.adaic.org/standards/05rm/html/RM-TTL.html Ada Reference Manual, ISO/IEC 8652:2005(E) Ed. 3
- rendezvous and monitor-like based
- http://en.cppreference.com/w/cpp/thread Thread support
- http://en.cppreference.com/w/cpp/atomic Atomics support
- https://cppandbeyond.wordpress.com/2011/04/11/session-announcement-the-c0x-memory-model-and-why-you-care Memory model
- http://www.gecode.org/ Gecode
- http://www.accellera.org/downloads/standards/systemc/about_systemc/ SystemC
- http://www.boost.org/libs/iostreams/ Boost.Iostreams
- http://code.google.com/p/boolinq/ Boolinq
- Web site: AraRat . 2019-09-15 . 2019-08-19 . https://web.archive.org/web/20190819105358/http://www.cs.technion.ac.il/~lkeren/scp.pdf . dead .
- http://www.open-mpi.org/ OpenMPI
- http://www.boost.org/libs/mpi/ Boost.MPI
- http://www.boost.org/libs/mpl/ Boost.MPL
- template metaprogramming
- http://cgi.di.uoa.gr/~smaragd/lc++/ LC++
- http://www.mpprogramming.com/Cpp/Default.aspx Castor
- https://bytemaster.github.com/boost_reflect/ Reflect Library
- http://www.open-std.org/JTC1/SC22/WG21/docs/papers/2013/n3534.html N3534
- http://www.boost.org/libs/spirit/ Boost.Spirit
- using TPL Dataflow
- only lambda support (lazy functional programming)
- using Reactive Extensions (Rx)
- https://clojure.org/about/concurrent_programming Clojure - Concurrent Programming
- https://github.com/clojure/core.async Clojure - core.async
- https://clojure.org/about/functional_programming Clojure - Functional Programming
- https://clojure.org/reference/macros Clojure - Macros
- https://github.com/clojure/core.logic/ Clojure - core.logic
- https://clojure.org/guides/threading_macros Clojure - Threading Macros Guide
- Web site: Light Table . 2019-04-08.
- https://clojure.org/reference/multimethods Multimethods and Hierarchies
- https://clojure.org/reference/agents Agents and Asynchronous Actions
- Web site: concurrency . CLiki.
- https://www.cliki.net/screamer
- https://www.cliki.net/Cells
- http://www.gigamonkeys.com/book/practical-an-html-generation-library-the-interpreter.html
- https://www.cliki.net/Distributed
- template metaprogramming using macros (see C++)
- https://www.cliki.net/Prolog
- multiple dispatch, method combinations
- [Common Lisp Object System]
- http://blog.vjeux.com/2011/lisp/lisp-chaining-operator.html implemented by the user via a short macro, example of implementation
- https://github.com/honix/Lire - Visual programming tool based on Common Lisp
- http://lisa.sourceforge.net/
- https://common-lisp.net/project/ecl/static/manual/ch31.html
- http://www.digitalmars.com/d/2.0/comparison.html D Language Feature Table
- http://www.digitalmars.com/d/2.0/phobos/std_algorithm.html Phobos std.algorithm
- http://dlang.org/mixin.html D language String Mixins
- class-based
- http://www.crockford.com/javascript/little.html The Little JavaScripter
- http://mckoss.com/jscript/object.htm Object-Oriented Programming in JavaScript
- promises, native extensions
- using Node.js' cluster module or child_process.fork method, web workers in the browser, etc.
- Web site: React – A JavaScript library for building user interfaces . 2019-04-08.
- Web site: TNG-Hooks . . 2019-04-08.
- Prototype-based
- Web site: Lodash documentation . 2019-04-08.
- Web site: mori . 2019-04-08.
- Web site: Light Table . 2019-04-08.
- using Reactive Extensions (RxJS)
- Web site: TNG-Hooks . . 2019-04-08.
- in Node.js via their events module
- in browsers via their native EventTarget API
- purely functional
- actor programming
- purely functional
- parameterized classes
- Web site: Prolog embedding . Haskell.org.
- Web site: Functional Reactive Programming . HaskellWiki.
- https://haskell-distributed.github.io/ Cloud Haskell
- purely functional
- Web site: Template Haskell . HaskellWiki.
- Web site: Logict: A backtracking logic-programming monad . Haskell.org.
- immutable
- Web site: Kollmansberger . Steve . Erwig . Martin . 30 May 2006 . Haskell Rules: Embedding Rule Systems in Haskell . Oregon State University.
- https://jcp.org/en/jsr/detail?id=331 JSR 331: Constraint Programming API
- https://github.com/GoogleCloudPlatform/DataflowJavaSDK Google Cloud Platform Dataflow SDK
- Web site: JuliaOpt/JuMP.jl . GitHub . JuliaOpt . 12 February 2020 . 11 February 2020.
- Web site: GitHub - MikeInnes/DataFlow.jl . . 2019-01-15.
- Web site: GitHub - JuliaGizmos/Reactive.jl: Reactive programming primitives for Julia . . 2018-12-28.
- https://github.com/davidanthoff/Query.jl Query almost anything in julia
- https://github.com/lilinjn/LilKanren.jl A collection of Kanren implementations in Julia
- multiple dispatch, not traditional single
- Web site: GitHub - abeschneider/PEGParser.jl: PEG Parser for Julia . . 2018-12-03.
- Web site: GitHub - gitfoxi/Parsimonious.jl: A PEG parser generator for Julia . . 2017-08-03.
- Lazy https://github.com/MikeInnes/Lazy.jl
- Web site: Execute loop iterations in parallel . mathworks.com . 21 October 2016.
- Web site: Write Constraints . mathworks.com . 21 October 2016.
- Web site: Getting Started with SimEvents . mathworks.com . 21 October 2016.
- Web site: Execute loop iterations in parallel . mathworks.com . 21 October 2016.
- Web site: Execute MATLAB expression in text - MATLAB eval . mathworks.com . 21 October 2016.
- Web site: Determine class of object . mathworks.com . 21 October 2016.
- Web site: Class Metadata . mathworks.com . 21 October 2016.
- Web site: Object-Oriented Programming . mathworks.com . 21 October 2016.
- Web site: Simulink . mathworks.com . 21 October 2016.
- http://perldoc.perl.org/threads.html interpreter based threads
- http://hop.perl.plover.com/book/ Higher Order Perl
- http://php.net/manual/en/index.php PHP Manual
- http://php.net/manual/en/index.php PHP Manual
- http://php.net/manual/en/index.php PHP Manual
- Web site: Parallel Processing and Multiprocessing in Python . Python Wiki . 21 October 2016.
- Web site: threading — Higher-level threading interface . docs.python.org . 21 October 2016.
- Web site: python-constraint . pypi.python.org . 21 October 2016.
- Web site: DistributedProgramming . Python Wiki . 21 October 2016.
- Web site: Chapter 9. Metaprogramming . chimera.labs.oreilly.com . 22 October 2016 . https://web.archive.org/web/20161023050954/http://chimera.labs.oreilly.com/books/1230000000393/ch09.html . 23 October 2016 . dead.
- Web site: Metaprogramming . readthedocs.io . 22 October 2016.
- Web site: PEP 443 – Single-dispatch generic functions . python.org . 22 October 2016.
- Web site: PEP 484 – Type Hints . python.org . 22 October 2016.
- Web site: PyDatalog . 22 October 2016.
- Web site: Light Table . 2019-04-08.
- Web site: Futureverse .
- Web site: future batchtools .
- Web site: Magrittr: A Forward Pipe Operator for R . cran.r-project.org\access-date=13 July 2017 . 17 November 2020.
- https://docs.racket-lang.org/guide/concurrency.html Racket Guide: Concurrency and Synchronization
- https://docs.racket-lang.org/rosette-guide/ The Rosette Guide
- https://docs.racket-lang.org/frtime/ FrTime: A Language for Reactive Programs
- https://docs.racket-lang.org/guide/parallelism.html#%28part._distributed-places%29 Racket Guide: Distributed Places
- https://docs.racket-lang.org/lazy/ Lazy Racket
- https://docs.perl6.org/language/concurrency Channels and other mechanisms
- Web site: Problem Solver module.
- https://docs.perl6.org/routine/==%3E Feed operator
- https://github.com/perl6/doc/issues/1744#issuecomment-360565196 Cro module
- Web site: Meta-programming: What, why and how . 2011-12-14.
- https://perl6advent.wordpress.com/2009/12/18/day-18-roles/ Parametrized Roles
- Web site: Meta-object protocol (MOP).
- https://docs.perl6.org/language/classtut Classes and Roles
- Web site: The Rust macros guide . Rust . 19 January 2015. rust-macros.
- Web site: The Rust compiler plugins guide . Rust . 19 January 2015. rust-plugins.
- http://doc.rust-lang.org/1.0.0-alpha/reference.html#generic-functions The Rust Reference §6.1.3.1
- http://www.scala-lang.org/sites/default/files/linuxsoft_archives/docu/files/ScalaOverview.pdf An Overview of the Scala Programming Language
- https://wayback.archive-it.org/all/20171003043151/http://www.scala-lang.org/sites/default/files/linuxsoft_archives/docu/files/ScalaReference.pdf Scala Language Specification
- actor programming
- http://doc.akka.io/docs/akka/snapshot/scala/dataflow.html Akka
- Web site: Tcl Programming/Introduction . en.wikibooks.org . 22 October 2016.
- Web site: TCLLIB - Tcl Standard Library: snitfaq . sourceforge.net . 22 October 2016.
- http://www.wolfram.com/language/for-experts/ Notes for Programming Language Experts
- https://reference.wolfram.com/language/tutorial/ExternalPrograms.html External Programs