PlusCal
PlusCal ist eine durch Leslie Lamport entwickelte formale Sprache zur Spezifikation nebenläufiger Algorithmen und Systeme. Es handelt sich um eine deklarative Sprache, wobei Sprachkonstrukte so gestaltet sind, dass sie einer imperativen Sprache sehr ähnlich sind. Die eher an eine imperative Programmiersprache erinnernde Syntax soll es Programmierern leichter machen, eine formale Sprache zur Spezifikation zu verwenden. Das Ziel ist hierbei, nicht einheitlich spezifizierten und hierdurch mehrdeutigen Pseudocode zu ersetzen.
Es existieren zwei verschiedene Syntax-Versionen von PlusCal. Die C-Syntax, wobei c für compact steht, ist eine kompakte Variante, die an vielen Stellen Klammern verwendet, um den Beginn und das Ende von Blöcken zu markieren. Sie ist gedacht für Programmierer, die die Programmiersprachen C, C++, C# oder Java verwenden. Die P-Syntax, wobei p für prolix steht, verwendet anstelle von Klammern Begriffe wie begin und end.
PlusCal basiert auf TLA+, wodurch sich TLA+ Ausdrücke in PlusCal verwenden lassen. Darüber hinaus können Spezifikationen von PlusCal in TLA+ übersetzt werden, um anschließend mit TLC überprüft zu werden. Ein entsprechendes Übersetzungsprogramm ist Teil der TLA+ Toolbox. Neben einem Übersetzungsprogramm beinhaltet die TLA+ Toolbox auch ein Programm zum Setzen von PlusCal Spezifikationen in LaTeX.
PlusCal wird unter anderem bei der Entwicklung von Amazon Web Services[1] eingesetzt.
Literatur
Bearbeiten- Leslie Lamport: The PlusCal Algorithm Language. In: Proceedings of the 6th International Colloquium on Theoretical Aspects of Computing (= ICTAC ’09). Springer-Verlag, Berlin, Heidelberg 2009, ISBN 978-3-642-03465-7, S. 36–60, doi:10.1007/978-3-642-03466-4_2 (research.microsoft.com [PDF; abgerufen am 31. Oktober 2015]).
- Leslie Lamport: Checking a Multithreaded Algorithm with +CAL. In: Proceedings of the 20th International Conference on Distributed Computing (= DISC’06). Springer-Verlag, Berlin, Heidelberg 2006, ISBN 3-540-44624-9, S. 151–163, doi:10.1007/11864219_11 (research.microsoft.com [PDF; abgerufen am 31. Oktober 2015]).
- Leslie Lamport: A PlusCal User’s Manual. C-Syntax∗ Version 1.8. Microsoft Research, 21. Oktober 2015 (research.microsoft.com [PDF; abgerufen am 31. Oktober 2015]).
- Leslie Lamport: A PlusCal User’s Manual. P-Syntax∗ Version 1.8. Microsoft Research, 21. Oktober 2015 (research.microsoft.com [PDF; abgerufen am 31. Oktober 2015]).
Weblinks
BearbeitenEinzelnachweise
Bearbeiten- ↑ Chris Newcombe, Tim Rath, Fan Zhang, Bogdan Munteanu, Marc Brooker, Michael Deardeuff: How Amazon Web Services Uses Formal Methods. In: Commun. ACM. Band 58, Nr. 4, März 2015, ISSN 0001-0782, S. 66–73, doi:10.1145/2699417.