Uploaded image for project: 'JDK'
  1. JDK
  2. JDK-8309342

Formally define the term "thread safe"

XMLWordPrintable

    • Icon: Enhancement Enhancement
    • Resolution: Unresolved
    • Icon: P3 P3
    • None
    • None
    • core-libs
    • None

      The term "thread safe" is used both in the Java Language Specification (e.g. in 17.5 final Field Semantics) and in the Java SE documentation but is not formally defined.

      From the annotation `@ThreadSafe` (which is not a part of Java SE), there is a tentative definition:

      "No sequences of accesses (reads and writes to public fields, calls to public methods) may put the object into an invalid state, regardless of the interleaving of those actions by the runtime, and without requiring any additional synchronization or coordination on the part of the caller."

      The above is based on code developed by Brian Goetz and Tim Peierls and concepts published in 'Java Concurrency in Practice' by Brian Goetz, Tim Peierls, Joshua Bloch, Joseph Bowbeer, David Holmes and Doug Lea.

      I think the term should be formally defined. Preferably in the JLS.

            Unassigned Unassigned
            pminborg Per-Ake Minborg
            Votes:
            0 Vote for this issue
            Watchers:
            3 Start watching this issue

              Created:
              Updated: