List of concurrent and parallel programming languages

From Wikipedia, the free encyclopedia
Jump to navigation Jump to search

Template:SHORTDESC: 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

[edit | edit source]

Dataflow programming

[edit | edit source]
  • CAL
  • E (also object-oriented)
  • Joule (also distributed)
  • LabVIEW (also synchronous, also object-oriented)
  • Lustre (also synchronous)
  • Preesm (also synchronous)
  • Signal (also synchronous)
  • SISAL
  • BMDFM

Distributed computing

[edit | edit source]

Event-driven and hardware description

[edit | edit source]

Functional programming

[edit | edit source]

Logic programming

[edit | edit source]

Monitor-based

[edit | edit source]

Multi-threaded

[edit | edit source]

Object-oriented programming

[edit | edit source]

Partitioned global address space (PGAS)

[edit | edit source]

Message passing

[edit | edit source]

Actor model

[edit | edit source]

CSP-based

[edit | edit source]

APIs/frameworks

[edit | edit source]

These application programming interfaces support parallelism in host languages.

See also

[edit | edit source]

References

[edit | edit source]
  1. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
  2. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
  3. ^ Documentation » The Python Standard Library: Concurrent Execution
  4. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
  5. ^ Alan Kay The Early History Of Smalltalk
  6. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).