English

Using session types as an effect system

Programming Languages 2016-02-12 v1

Abstract

Side effects are a core part of practical programming. However, they are often hard to reason about, particularly in a concurrent setting. We propose a foundation for reasoning about concurrent side effects using sessions. Primarily, we show that session types are expressive enough to encode an effect system for stateful processes. This is formalised via an effect-preserving encoding of a simple imperative language with an effect system into the pi-calculus with session primitives and session types (into which we encode effect specifications). This result goes towards showing a connection between the expressivity of session types and effect systems. We briefly discuss how the encoding could be extended and applied to reason about and control concurrent side effects.

Keywords

Cite

@article{arxiv.1602.03591,
  title  = {Using session types as an effect system},
  author = {Dominic Orchard and Nobuko Yoshida},
  journal= {arXiv preprint arXiv:1602.03591},
  year   = {2016}
}

Comments

In Proceedings PLACES 2015, arXiv:1602.03254

R2 v1 2026-06-22T12:48:04.933Z