List of concurrent and parallel programming languages

This article lists concurrent and parallel programming languages, categorising them by a defining paradigm. A concurrent 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.

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

Actor model

Main article: Actor model

Coordination languages

Dataflow

Main article: Dataflow programming

Distributed

Main article: Distributed computing

Event-driven and hardware description

Main articles: Event-driven programming and Hardware Description Language

Functional

Logic programming

Main article: Logic programming

Multi-threaded

Object-oriented

Partitioned global address space (PGAS)

Message passing

Main article: Message passing

CSP based

APIs/frameworks

These application programming interfaces support parallelism in host languages.

See also