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.
- Axum - a domain-specific language being developed by Microsoft.
- Elixir (runs on the Erlang VM)
- E (also object-oriented)
- Joule (also distributed)
- LabView (also synchronous)
- Lustre (also synchronous)
- Signal (also synchronous)
- Oz - Multi-paradigm language with particular support for constraint and distributed programming.
Event-driven and hardware description
- Esterel (also synchronous)
- Verilog-AMS - math modeling of continuous time systems
- Cilk Plus
- Fork - Programming language for the PRAM model.
- C++ AMP
- D Programming Language
- Eiffel SCOOP (Simple Concurrent Object-Oriented Programming)
- Emerald (also distributed)
- Join Java - A Java-based language with features from the join-calculus.
Partitioned global address space (PGAS)
- Concurrent Pascal (developed by Per Brinch Hansen)
- Joyce (developed by Per Brinch Hansen)
- Limbo (also distributed)
- Occam-π - A derivative of Occam that integrates features from the pi-calculus
- SuperPascal (developed by Per Brinch Hansen)
- XC - A C-based language, integrating features from Occam, developed by XMOS
These application programming interfaces support parallelism in host languages.