List of concurrent and parallel programming languages

From Wikipedia, the free encyclopedia

This article lists concurrent and parallel programming languages, categorizing them by a defining paradigm. Concurrent and parallel programming languages involve multiple timelines. Such languages provide synchronization constructs whose behavior is defined by a parallel execution model. A concurrent programming language is defined as one which uses the concept of simultaneously executing processes or threads of execution as a means of structuring a program. A parallel language is able to express programs that are executable on more than one processor. Both types are listed, as concurrency is a useful tool in expressing parallelism, but it is not necessary. In both cases, the features must be part of the language syntax and not an extension such as a library (libraries such as the posix-thread library implement a parallel execution model but lack the syntax and grammar required to be a programming language).

The following categories aim to capture the main, defining feature of the languages contained, but they are not necessarily orthogonal.

Coordination languages[]

Dataflow programming[]

  • CAL
  • E (also object-oriented)
  • Joule (also distributed)
  • LabView (also synchronous)
  • Lustre (also synchronous)
  • Preesm (also synchronous)
  • Signal (also synchronous)
  • SISAL
  • BMDFM

Distributed computing[]

Event-driven and hardware description[]

Functional programming[]

Logic programming[]

Monitor-based[]

Multi-threaded[]

Object-oriented programming[]

Partitioned global address space (PGAS)[]

Message passing[]

  • Ateji PX - An extension of Java with parallel primitives inspired from pi-calculus.
  • Rust[4]
  • Smalltalk[5]: p.17 Part IV, see table following fig. 11–29 

Actor model[]

CSP-based[]

APIs/frameworks[]

These application programming interfaces support parallelism in host languages.

See also[]

References[]

  1. ^ Thom Frühwirth (9 July 2009). Constraint Handling Rules. Cambridge University Press. ISBN 978-0-521-87776-3.
  2. ^ "Threads - The Rust Programming Language". doc.rust-lang.org. Retrieved 2017-09-15.
  3. ^ Documentation » The Python Standard Library » Concurrent Execution
  4. ^ "Message Passing - The Rust Programming Language". doc.rust-lang.org. Retrieved 2017-09-15.
  5. ^ Alan Kay The Early History Of Smalltalk
  6. ^ "Crystal Programming Language – Concurrency". Retrieved 10 August 2018.
Retrieved from ""