public abstract class ScopedMemory extends MemoryArea
ScopedMemory is the abstract base class of all classes dealing with
 representations of memory spaces which have a limited lifetime. In general,
 objects allocated in scoped memory are freed when, and only when, no
 schedulable object has access to the objects in the scoped memory.
 
 A ScopedMemory area is a connection to a particular region of memory
 and reflects the current status of that memory. The object does not
 necessarily contain direct references to the region of memory. That is
 implementation dependent.
 
 When a ScopedMemory area is instantiated, the object itself is
 allocated from the current memory allocation context, but the memory space
 that object represents (its backing store) is allocated from memory that is
 not otherwise directly visible to Java code; e.g., it might be allocated with
 the C malloc function. This backing store behaves effectively as if
 it were allocated when the associated scoped memory object is constructed and
 freed at that scoped memory object's finalization.
 
 The enter() method of ScopedMemory is one
 mechanism used to make a memory area the current allocation context. The
 other mechanism for activating a memory area is making it the initial memory
 area for a realtime thread or async event handler. Entry into the scope is
 accomplished, for example, by calling the method:
 
      public void enter(Runnable logic)
 
 
 where logic is an instance of Runnable whose run()
 method represents the entry point of the code that will run in the new scope.
 Exit from the scope occurs between the time the runnable.run() method
 completes and the time control returns from the enter() method.
 By default, allocations of objects within runnable.run() are taken
 from the backing store of the ScopedMemory.
 
 ScopedMemory is an abstract class, but all specified methods include
 implementations. The responsibilities of MemoryArea,
 ScopedMemory and the classes that extend ScopedMemory are not
 specified. In JamaicaVM, application code is not permitted to create
 instances of user-defined direct subclasses of ScopedMemory.
| Modifier and Type | Method and Description | 
|---|---|
| void | enter()Associates this memory area with the current schedulable for the duration
 of the execution of the  run()method of the instance ofRunnablegiven in the constructor. | 
| boolean | enter(java.util.function.BooleanSupplier logic)Same as  MemoryArea.enter(Runnable)except that the executed method is
 calledgetAsBoolean()and a boolean is returned. | 
| double | enter(java.util.function.DoubleSupplier logic)Same as  MemoryArea.enter(Runnable)except that the executed method is
 calledgetAsDouble()and a double is returned. | 
| int | enter(java.util.function.IntSupplier logic)Same as  MemoryArea.enter(Runnable)except that the executed method is
 calledgetAsInt()and an int is returned. | 
| long | enter(java.util.function.LongSupplier logic)Same as  MemoryArea.enter(Runnable)except that the executed method is
 calledgetAsLong()and a long is returned. | 
| void | enter(java.lang.Runnable logic)Associates this memory area with the current schedulable for the duration
 of the execution of the  run()method of the givenRunnable. | 
| <T> T | enter(java.util.function.Supplier<T> logic)Same as  MemoryArea.enter(Runnable)except that the executed method is
 calledget()and an object is returned. | 
| boolean | executeInArea(java.util.function.BooleanSupplier logic)Executes the run method from the  logicparameter using
 this memory area as the current allocation context. | 
| double | executeInArea(java.util.function.DoubleSupplier logic)Executes the run method from the  logicparameter using
 this memory area as the current allocation context. | 
| int | executeInArea(java.util.function.IntSupplier logic)Executes the run method from the  logicparameter using
 this memory area as the current allocation context. | 
| long | executeInArea(java.util.function.LongSupplier logic)Executes the run method from the  logicparameter using
 this memory area as the current allocation context. | 
| void | executeInArea(java.lang.Runnable logic)Executes the run method from the  logicparameter using
 this memory area as the current allocation context. | 
| <T> T | executeInArea(java.util.function.Supplier<T> logic)Executes the run method from the  logicparameter using
 this memory area as the current allocation context. | 
| MemoryArea | getParent()Returns the parent memory area when there is a parent and it is a scoped
 memory. | 
| java.lang.Object | getPortal()Returns a reference to the portal object in this instance of
  ScopedMemory. | 
| int | getReferenceCount()Returns the reference count of this  ScopedMemory. | 
| static long | globalBackingStoreConsumed() | 
| static long | globalBackingStoreRemaining() | 
| static long | globalBackingStoreSize() | 
| void | join()Waits until the reference count of this  ScopedMemorygoes down to
 zero. | 
| void | join(HighResolutionTime<?> time)Waits at most until the time designated by the  timeparameter for
 the reference count of thisScopedMemoryto drop to zero. | 
| void | joinAndEnter()In the error-free case,  joinAndEntercombinesjoin();enter();such that noenter()from another
 schedulable can intervene between the two method invocations. | 
| boolean | joinAndEnter(java.util.function.BooleanSupplier logic)Same as  joinAndEnter(Runnable)except that the executed
 method is calledgetand abooleanis returned. | 
| boolean | joinAndEnter(java.util.function.BooleanSupplier logic,
            HighResolutionTime<?> time)Same as  joinAndEnter(Runnable, HighResolutionTime)except that
 the executed method is calledgetand abooleanis returned. | 
| double | joinAndEnter(java.util.function.DoubleSupplier logic)Same as  joinAndEnter(Runnable)except that the executed
 method is calledgetand adoubleis returned. | 
| double | joinAndEnter(java.util.function.DoubleSupplier logic,
            HighResolutionTime<?> time)Same as  joinAndEnter(Runnable, HighResolutionTime)except that
 the executed method is calledgetand adoubleis returned. | 
| void | joinAndEnter(HighResolutionTime<?> time)In the error-free case,  joinAndEntercombinesjoin();enter();such that noenter()from another
 schedulable can intervene between the two method invocations. | 
| int | joinAndEnter(java.util.function.IntSupplier logic)Same as  joinAndEnter(Runnable)except that the executed
 method is calledgetand anintis returned. | 
| int | joinAndEnter(java.util.function.IntSupplier logic,
            HighResolutionTime<?> time)Same as  joinAndEnter(Runnable, HighResolutionTime)except that
 the executed method is calledgetand anintis returned. | 
| long | joinAndEnter(java.util.function.LongSupplier logic)Same as  joinAndEnter(Runnable)except that the executed
 method is calledgetand alongis returned. | 
| long | joinAndEnter(java.util.function.LongSupplier logic,
            HighResolutionTime<?> time)Same as  joinAndEnter(Runnable, HighResolutionTime)except that
 the executed method is calledgetand alongis returned. | 
| void | joinAndEnter(java.lang.Runnable logic)In the error-free case,  joinAndEntercombinesjoin();enter();such that noenter()from another
 schedulable can intervene between the two method invocations. | 
| void | joinAndEnter(java.lang.Runnable logic,
            HighResolutionTime<?> time)In the error-free case,  joinAndEntercombinesjoin();enter();such that noenter()from another
 schedulable can intervene between the two method invocations. | 
| <P> P | joinAndEnter(java.util.function.Supplier<P> logic,
            HighResolutionTime<?> time)Same as  joinAndEnter(Runnable, HighResolutionTime)except that
 the executed method is calledgetand an object
 is returned. | 
| <T> T | joinAndEnter(java.util.function.Supplier<T> logic)Same as  joinAndEnter(Runnable)except that the executed
 method is calledgetand an object is returned. | 
| boolean | joinAndEnterInternal(java.util.function.BooleanSupplier logic,
                    HighResolutionTime<?> time)Same as  joinAndEnterInternal(Runnable, HighResolutionTime)except that the executed method is calledgetand abooleanis returned. | 
| double | joinAndEnterInternal(java.util.function.DoubleSupplier logic,
                    HighResolutionTime<?> time)Same as  joinAndEnterInternal(Runnable, HighResolutionTime)except that the executed method is calledgetand adoubleis returned. | 
| int | joinAndEnterInternal(java.util.function.IntSupplier logic,
                    HighResolutionTime<?> time)Same as  joinAndEnterInternal(Runnable, HighResolutionTime)except that the executed method is calledgetand anintis returned. | 
| long | joinAndEnterInternal(java.util.function.LongSupplier logic,
                    HighResolutionTime<?> time)Same as  joinAndEnterInternal(Runnable, HighResolutionTime)except that the executed method is calledgetand alongis returned. | 
| <P> P | joinAndEnterInternal(java.util.function.Supplier<P> logic,
                    HighResolutionTime<?> time)Same as  joinAndEnterInternal(Runnable, HighResolutionTime)except that the executed method is calledgetand an object
 is returned. | 
| boolean | mayHoldReferenceTo()Determines whether an object  Aallocated in the memory area
 represented bythiscan hold a reference to an objectBallocated in the current memory area. | 
| boolean | mayHoldReferenceTo(java.lang.Object value)Determines whether an object allocated in the memory area
 represented by  thiscan hold a reference to the objectvalue. | 
| void | setPortal(java.lang.Object object)Sets the portal object of the memory area represented by this
 instance of  ScopedMemoryto the given object. | 
| java.lang.String | toString()Returns a user-friendly representation of this
  ScopedMemoryof the form<class-name>@<num>"where <class-name>
 is the name of the class, e.g. | 
getMemoryArea, memoryConsumed, memoryRemaining, newArray, newArrayInArea, newInstance, newInstance, sizepublic static long globalBackingStoreSize()
public static long globalBackingStoreConsumed()
public static long globalBackingStoreRemaining()
public boolean mayHoldReferenceTo()
MemoryAreaA allocated in the memory area
 represented by this can hold a reference to an object
 B allocated in the current memory area.mayHoldReferenceTo in class MemoryAreatrue only when the current memory area is also an
 instance of PerennialMemory.public boolean mayHoldReferenceTo(java.lang.Object value)
MemoryAreathis can hold a reference to the object
 value.mayHoldReferenceTo in class MemoryAreavalue - The object to test.public void enter()
           throws ScopedCycleException
run() method of the instance of Runnable given in the constructor. During this period of execution, this
 memory area becomes the default allocation context until another default
 allocation context is selected (using enter, or executeInArea(java.lang.Runnable)) or the enter method exits.enter in class MemoryAreaScopedCycleException - when this invocation would break
                                          the single parent rule.ThrowBoundaryError - Thrown when the JVM needs to
                                          propagate an exception allocated
                                          in this scope to (or
                                          through) the memory area of the
                                          caller. Storing a reference to
                                          that exception would cause an
                                          IllegalAssignmentError,
                                          so the JVM may not be permitted to
                                          deliver the exception.  The ThrowBoundaryError
                                          is allocated in the current
                                          allocation context and contains
                                          information about the exception it
                                          replaces.IllegalTaskStateException - when the execution context is not
                                          an instance of Schedulable
                                          or when this method is invoked
                                          during finalization of objects in
                                          scoped memory and entering this
                                          scoped memory area would force
                                          deletion of the execution context
                                          that triggered finalization.  This
                                          would include the scope containing
                                          the execution context, and the
                                          scope (if any) containing the
                                          scope containing execution
                                          context.StaticIllegalArgumentException - when the caller is a schedulable
                                          and a null value for
                                          logic was supplied when
                                          the memory area was constructed.MemoryAccessError - when caller is a schedulable that
                                          may not use the heap and this
                                          memory area's logic value is
                                          allocated in heap memory.public void enter(java.lang.Runnable logic)
           throws ScopedCycleException
run() method of the given Runnable.
 During this period of execution, this memory area becomes the default
 allocation context until another default allocation context is selected
 (using enter, or executeInArea(java.lang.Runnable)) or the enter
 method exits.enter in class MemoryArealogic - The Runnable object whose run() method should be
              invoked.ScopedCycleException - when this invocation would break
                                          the single parent rule.ThrowBoundaryError - when the JVM needs to propagate an
                                          exception allocated in this scope to (or through) the
                                          memory area of the caller. Storing
                                          a reference to that exception
                                          would cause an IllegalAssignmentError,
                                          so the JVM may not be permitted to
                                          deliver the exception.  The ThrowBoundaryError
                                          is allocated in the current
                                          allocation context and contains
                                          information about the exception it
                                          replaces.IllegalTaskStateException - when the execution context is not
                                          an instance of Schedulable
                                          or when this method is invoked
                                          during finalization of objects in
                                          scoped memory and entering this
                                          scoped memory area would force
                                          deletion of the task that
                                          triggered finalization.  This
                                          would include the scope containing
                                          the task, and the scope (if any)
                                          containing the scope containing
                                          task.StaticIllegalArgumentException - when the caller is a schedulable
                                          and logic is
                                          null.public boolean enter(java.util.function.BooleanSupplier logic)
              throws ScopedCycleException
MemoryAreaMemoryArea.enter(Runnable) except that the executed method is
 called getAsBoolean() and a boolean is returned.enter in class MemoryArealogic - The object whose getAsboolean() method is to
 be executed.getAsBoolean() method.ScopedCycleExceptionpublic double enter(java.util.function.DoubleSupplier logic)
             throws ScopedCycleException
MemoryAreaMemoryArea.enter(Runnable) except that the executed method is
 called getAsDouble() and a double is returned.enter in class MemoryArealogic - The object whose getAsDouble() method is to be
 executed.getAsDouble() method.ScopedCycleExceptionpublic int enter(java.util.function.IntSupplier logic)
          throws ScopedCycleException
MemoryAreaMemoryArea.enter(Runnable) except that the executed method is
 called getAsInt() and an int is returned.enter in class MemoryArealogic - The object whose getAsInt() method is to be
 executed.getAsInt() method.ScopedCycleExceptionpublic long enter(java.util.function.LongSupplier logic)
           throws ScopedCycleException
MemoryAreaMemoryArea.enter(Runnable) except that the executed method is
 called getAsLong() and a long is returned.enter in class MemoryArealogic - The object whose getAsLong() method is to be
 executed.getAsLong() method.ScopedCycleExceptionpublic <T> T enter(java.util.function.Supplier<T> logic)
            throws ScopedCycleException
MemoryAreaMemoryArea.enter(Runnable) except that the executed method is
 called get() and an object is returned. The
 The get() method must ensure that the returned object is
 allocated outside the area, when the area is not a PerennialMemory.enter in class MemoryArealogic - The object whose get() method is to be
 executed.get() method.ScopedCycleExceptionpublic java.lang.Object getPortal()
                           throws MemoryAccessError,
                                  IllegalAssignmentError
ScopedMemory.
 
 Assignment rules are enforced on the value returned by getPortal()
 as if the return value were first stored in an object allocated in the
 current allocation context, then moved to its final destination.
null when there is no
 portal object.  The portal value is always set to null when the
 contents of the memory are deleted.IllegalAssignmentError - when a reference to the portal
                                          object may not be stored in the
                                          caller's allocation context; that
                                          is, when the object is allocated
                                          in a more deeply nested scoped
                                          memory than the current allocation
                                          context or not on the caller's
                                          scope stack.IllegalTaskStateException - when the execution context is not
                                          an instance of
                                          Schedulable.MemoryAccessErrorpublic void setPortal(java.lang.Object object)
ScopedMemory to the given object. The object must
 have been allocated in this ScopedMemory instance.object - The object which will become the portal for this. When null the previous portal object remains the portal object
               for this or when there was no previous portal object then
               there is still no portal object for this.java.lang.IllegalThreadStateException - when the execution context is not an
                                     instance of
                                     Schedulable.IllegalAssignmentError - when the execution context is an
                                     instance of
                                     Schedulable,
                                     and object is not allocated in
                                     this scoped memory instance and not
                                     null.InaccessibleAreaException - when the execution context is a
                                     schedulable, this memory area
                                     is not in the caller's scope stack and
                                     object is not null.public int getReferenceCount()
ScopedMemory.
 Note that a reference count of zero reliably means that the scope is not referenced, but other reference counts are subject to artifacts of lazy/eager maintenance by the implementation.
ScopedMemory.public MemoryArea getParent()
null is
 returned. This reduces the need for casting the returned value.null or the parent scopepublic java.lang.String toString()
ScopedMemory of the form
 <class-name>@<num>" where <class-name>
 is the name of the class, e.g. javax.realtime.memory.ScopedMemory, and
 <num> is a number that uniquely identifies this scoped memory area.toString in class java.lang.Objectpublic void join(HighResolutionTime<?> time) throws java.lang.InterruptedException
time parameter for
 the reference count of this ScopedMemory to drop to zero. Returns
 immediately when the memory area is unreferenced.
 
 Since the time is expressed as a HighResolutionTime,
 this method is an accurate timer with nanosecond granularity. The actual
 resolution of the timer and even the quantity it measures depends on the
 clock associated with time. The delay time may be relative or
 absolute. When relative, then the delay is the amount of time given by
 time, and measured by its associated clock. When absolute, then the
 delay is until the indicated value is reached by the clock. When the given
 absolute time is less than or equal to the current value of the clock, the
 call to join returns immediately.
time - When this time is an absolute time, the wait is bounded by that
             point in time. When the time is a relative time (or a member of
             the RationalTime subclass of RelativeTime) the
             wait is bounded by a the specified interval from some time
             between the time join is called and the time it starts
             waiting for the reference count to reach zero.java.lang.InterruptedException - when this schedulable is
                                          interrupted by
                                          RealtimeThread.interrupt()
                                          or
                                          AsynchronouslyInterruptedException.fire()
                                          while waiting for the reference
                                          count to go to zero.IllegalTaskStateException - when the execution context is not
                                          an instance of
                                          Schedulable.StaticIllegalArgumentException - when the execution context is a
                                          schedulable and time is
                                          null.java.lang.UnsupportedOperationException - when the wait operation is not
                                          supported using the clock
                                          associated with time.public void join()
          throws java.lang.InterruptedException
ScopedMemory goes down to
 zero.  Returns immediately when the memory is unreferenced.java.lang.InterruptedException - when this schedulable is
                                          interrupted by
                                          RealtimeThread.interrupt()
                                          or
                                          AsynchronouslyInterruptedException.fire()
                                          while waiting for the reference
                                          count to go to zero.IllegalTaskStateException - when the execution context is not
                                          an instance of
                                          Schedulable.public void joinAndEnter()
                  throws java.lang.InterruptedException
joinAndEnter combines
 join();enter(); such that no enter() from another
 schedulable can intervene between the two method invocations. The resulting
 method will wait for the reference count on this ScopedMemory to
 reach zero, then enters the ScopedMemory and executes the
 run method from logic passed in the constructor. When no
 instance of Runnable was passed to the memory area's constructor,
 the method throws StaticIllegalArgumentException immediately.
 
 When multiple threads are waiting in joinAndEnter family methods
 for a memory area, at most one of them will be released each time
 the reference count goes to zero.
 
 Note that although joinAndEnter guarantees that the reference count
 is zero when the schedulable is released for entry, it does not guarantee
 that the reference count will remain one for any length of time.
 A subsequent enter could raise the reference count to two.
java.lang.InterruptedException - when this schedulable is
                                             interrupted by RealtimeThread.interrupt()
                                             or
                                             AsynchronouslyInterruptedException.fire()
                                             while waiting for the reference
                                             count to go to zero.IllegalTaskStateException - when the execution context is
                                             not an instance of Schedulable or
                                             when this method is invoked
                                             during finalization of objects
                                             in scoped memory and entering
                                             this scoped memory area would
                                             force deletion of the task that
                                             triggered finalization.  This
                                             would include the scope
                                             containing the task, and the
                                             scope (if any) containing the
                                             scope containing the task.ThrowBoundaryError - when the JVM needs to propagate
                                             an exception allocated in
                                             this scope to (or
                                             through) the memory area of the
                                             caller. Storing a reference to
                                             that exception would cause an
                                             IllegalAssignmentError,
                                             so the JVM may not be permitted
                                             to deliver the exception.  The
                                             ThrowBoundaryError
                                             is allocated in the current
                                             allocation context and contains
                                             information about the exception
                                             it replaces.ScopedCycleException - when this invocation would
                                             break the single parent rule.StaticIllegalArgumentException - when the execution context is a
                                             schedulable and no non-null
                                             logic value was
                                             supplied to the memory area's
                                             constructor.MemoryAccessError - when caller is a non-heap
                                             schedulable and this memory
                                             area's logic value is allocated
                                             in heap memory.public void joinAndEnter(HighResolutionTime<?> time) throws java.lang.InterruptedException
joinAndEnter combines
 join();enter(); such that no enter() from another
 schedulable can intervene between the two method invocations. The resulting
 method will wait for the reference count on this ScopedMemory to
 reach zero, or for the current time to reach the designated time, then
 enter the ScopedMemory and execute the run method from
 Runnable object passed to the constructor. When no instance of
 Runnable was passed to the memory area's constructor, the method
 throws StaticIllegalArgumentException immediately.
 
 When multiple threads are waiting in joinAndEnter family
 methods for a memory area, at most one of them will be released
 each time the reference count goes to zero.
 
 Since the time is expressed as a HighResolutionTime,
 this method has an accurate timer with nanosecond granularity. The actual
 resolution of the timer and even the quantity it measures depends on the
 clock associated with time. The delay time may be relative or
 absolute. When relative, then the calling thread is blocked for at most the
 amount of time given by time, and measured by its associated clock.
 When absolute, then the time delay is until the indicated value is reached
 by the clock. When the given absolute time is less than or equal to the
 current value of the clock, the call to joinAndEnter behaves
 effectively like enter().
 
 Note that expiration of time may cause control to enter the memory
 area before its reference count has gone to zero.
time - The time that bounds the wait.ThrowBoundaryError - when the JVM needs to propagate
                                             an exception allocated in
                                             this scope to (or
                                             through) the memory area of the
                                             caller. Storing a reference to
                                             that exception would cause an
                                             IllegalAssignmentError,
                                             so the JVM may not be permitted
                                             to deliver the exception. The
                                             ThrowBoundaryError
                                             is allocated in the current
                                             allocation context and contains
                                             information about the exception
                                             it replaces.java.lang.InterruptedException - when this schedulable is
                                             interrupted by
                                             RealtimeThread.interrupt()
                                             or
                                             AsynchronouslyInterruptedException.fire()
                                             while waiting for the reference
                                             count to go to zero.IllegalTaskStateException - when the execution context is
                                             not an instance of
                                             Schedulable
                                             or when this method is invoked
                                             during finalization of objects
                                             in scoped memory and entering
                                             this scoped memory area would
                                             force deletion of the task that
                                             triggered finalization. This
                                             would include the scope
                                             containing the task, and the
                                             scope (if any) containing the
                                             scope containing the task.ScopedCycleException - when the execution context is a
                                             schedulable and this invocation
                                             would break the single parent
                                             rule.StaticIllegalArgumentException - when the execution context is a
                                             schedulable, and time
                                             is null or no non-null
                                             logic value was
                                             supplied to the memory area's
                                             constructor.java.lang.UnsupportedOperationException - when the wait operation is not
                                             supported using the clock
                                             associated with time.MemoryAccessError - when calling schedulable may
                                             not use the heap and this
                                             memory area's logic value is
                                             allocated in heap memory.public void joinAndEnter(java.lang.Runnable logic)
                  throws java.lang.InterruptedException,
                         StaticIllegalArgumentException,
                         IllegalTaskStateException,
                         ThrowBoundaryError,
                         ScopedCycleException,
                         StaticIllegalStateException
joinAndEnter combines
 join();enter(); such that no enter() from another
 schedulable can intervene between the two method invocations. The resulting
 method will wait for the reference count on this ScopedMemory to
 reach zero, then enter the ScopedMemory and execute the run
 method from logic
 
 When logic is null, the method throws
 StaticIllegalArgumentException immediately.
 
 When multiple threads are waiting in joinAndEnter family methods
 for a memory area, at most one of them will be released each time
 the reference count goes to zero.
 
 Note that although joinAndEnter guarantees that the reference count
 is zero when the schedulable is released for entry, it does not guarantee
 that the reference count will remain one for any length of time.
 A subsequent enter could raise the reference count to two.
logic - The Runnable object which contains the code to
              execute.java.lang.InterruptedException - when this schedulable is
                                             interrupted by RealtimeThread.interrupt()
                                             or AsynchronouslyInterruptedException.fire()
                                             while waiting for the reference
                                             count to go to zero.IllegalTaskStateException - when the execution context is
                                             not an instance of Schedulable or
                                             when this method is invoked
                                             during finalization of objects
                                             in scoped memory and entering
                                             this scoped memory area would
                                             force deletion of the task that
                                             triggered finalization. This
                                             would include the scope
                                             containing the task, and the
                                             scope (if any) containing the
                                             scope containing the task.ThrowBoundaryError - thrown when the JVM needs to
                                             propagate an exception
                                             allocated in this scope
                                             to (or through) the memory area
                                             of the caller. Storing a
                                             reference to that exception
                                             would cause an IllegalAssignmentError,
                                             so the JVM may not be permitted
                                             to deliver the exception.  The
                                             ThrowBoundaryError
                                             is allocated in the current
                                             allocation context and contains
                                             information about the exception
                                             it replaces.ScopedCycleException - when this invocation would
                                             break the single parent rule.StaticIllegalArgumentException - when the execution context is a
                                             schedulable and logic
                                             is null.java.lang.IllegalStateException - JamaicaVM: when the caller is a
                                             non-realtime Java thread and
                                             -strictRTSJ is set.StaticIllegalStateExceptionpublic <T> T joinAndEnter(java.util.function.Supplier<T> logic)
                   throws java.lang.InterruptedException
joinAndEnter(Runnable) except that the executed
 method is called get and an object is returned.logic - The object whose get method will be executed.java.lang.InterruptedExceptionpublic boolean joinAndEnter(java.util.function.BooleanSupplier logic)
                     throws java.lang.InterruptedException
joinAndEnter(Runnable) except that the executed
 method is called get and a boolean is returned.logic - The object whose get method will be executed.java.lang.InterruptedExceptionpublic int joinAndEnter(java.util.function.IntSupplier logic)
                 throws java.lang.InterruptedException
joinAndEnter(Runnable) except that the executed
 method is called get and an int is returned.logic - The object whose get method will be executed.java.lang.InterruptedExceptionpublic long joinAndEnter(java.util.function.LongSupplier logic)
                  throws java.lang.InterruptedException
joinAndEnter(Runnable) except that the executed
 method is called get and a long is returned.logic - The object whose get method will be executed.java.lang.InterruptedExceptionpublic double joinAndEnter(java.util.function.DoubleSupplier logic)
                    throws java.lang.InterruptedException
joinAndEnter(Runnable) except that the executed
 method is called get and a double is returned.logic - The object whose get method will be executed.java.lang.InterruptedExceptionpublic void joinAndEnter(java.lang.Runnable logic,
                         HighResolutionTime<?> time)
                  throws java.lang.InterruptedException
joinAndEnter combines
 join();enter(); such that no enter() from another
 schedulable can intervene between the two method invocations. The resulting
 method will wait for the reference count on this ScopedMemory to
 reach zero, or for the current time to reach the designated time, then
 enter the ScopedMemory and execute the run method from
 logic.
 
 Since the time is expressed as a HighResolutionTime,
 this method is an accurate timer with nanosecond granularity. The actual
 resolution of the timer and even the quantity it measures depends on the
 clock associated with time. The delay time may be relative or
 absolute. When relative, then the delay is the amount of time given by
 time, and measured by its associated clock. When absolute, then the
 delay is until the indicated value is reached by the clock. When the given
 absolute time is less than or equal to the current value of the clock, the
 call to joinAndEnter behaves effectively like enter(Runnable).
 
 The method throws StaticIllegalArgumentException immediately when
 logic is null.
 
 When multiple threads are waiting in joinAndEnter family methods
 for a memory area, at most one of them will be released each time
 the reference count goes to zero.
 
 Note that expiration of time may cause control to enter the memory
 area before its reference count has gone to zero.
logic - The Runnable object which contains the code to
              execute.time - The time that bounds the wait.java.lang.InterruptedException - when this schedulable is
                                             interrupted by
                                             RealtimeThread.interrupt()
                                             or
                                             AsynchronouslyInterruptedException.fire()
                                             while waiting for the reference
                                             count to go to zero.IllegalTaskStateException - when the execution context is
                                             not an instance of
                                             Schedulable
                                             or when this method is invoked
                                             during finalization of objects
                                             in scoped memory and entering
                                             this scoped memory area would
                                             force deletion of the task that
                                             triggered finalization.  This
                                             would include the scope
                                             containing the task, and the
                                             scope (if any) containing the
                                             scope containing the task.ThrowBoundaryError - when the JVM needs to propagate
                                             an exception allocated in
                                             this scope to (or
                                             through) the memory area of the
                                             caller. Storing a reference to
                                             that exception would cause a
                                             IllegalAssignmentError,
                                             so the JVM may not be permitted
                                             to deliver the exception. The
                                             ThrowBoundaryError
                                             is preallocated and saves
                                             information about the exception
                                             it replaces.ScopedCycleException - when the execution context is a
                                             schedulable and this invocation
                                             would break the single parent
                                             rule.StaticIllegalArgumentException - when the execution context is a
                                             schedulable and time or
                                             logic is null.java.lang.UnsupportedOperationException - when the wait operation is not
                                             supported using the clock
                                             associated with time.public <P> P joinAndEnter(java.util.function.Supplier<P> logic,
                          HighResolutionTime<?> time)
                   throws java.lang.InterruptedException
joinAndEnter(Runnable, HighResolutionTime) except that
 the executed method is called get and an object
 is returned.logic - The object whose get method will be executed.java.lang.InterruptedExceptionpublic boolean joinAndEnter(java.util.function.BooleanSupplier logic,
                            HighResolutionTime<?> time)
                     throws java.lang.InterruptedException
joinAndEnter(Runnable, HighResolutionTime) except that
 the executed method is called get and a boolean
 is returned.logic - The object whose get method will be executed.java.lang.InterruptedExceptionpublic int joinAndEnter(java.util.function.IntSupplier logic,
                        HighResolutionTime<?> time)
                 throws java.lang.InterruptedException
joinAndEnter(Runnable, HighResolutionTime) except that
 the executed method is called get and an int
 is returned.logic - The object whose get method will be executed.java.lang.InterruptedExceptionpublic long joinAndEnter(java.util.function.LongSupplier logic,
                         HighResolutionTime<?> time)
                  throws java.lang.InterruptedException
joinAndEnter(Runnable, HighResolutionTime) except that
 the executed method is called get and a long
 is returned.logic - The object whose get method will be executed.java.lang.InterruptedExceptionpublic double joinAndEnter(java.util.function.DoubleSupplier logic,
                           HighResolutionTime<?> time)
                    throws java.lang.InterruptedException
joinAndEnter(Runnable, HighResolutionTime) except that
 the executed method is called get and a double
 is returned.logic - The object whose get method will be executed.java.lang.InterruptedExceptionpublic <P> P joinAndEnterInternal(java.util.function.Supplier<P> logic,
                                  HighResolutionTime<?> time)
                           throws java.lang.InterruptedException
joinAndEnterInternal(Runnable, HighResolutionTime)
 except that the executed method is called get and an object
 is returned.logic - The object whose get method will be executed.java.lang.InterruptedExceptionpublic boolean joinAndEnterInternal(java.util.function.BooleanSupplier logic,
                                    HighResolutionTime<?> time)
                             throws java.lang.InterruptedException
joinAndEnterInternal(Runnable, HighResolutionTime)
 except that the executed method is called get and a
 boolean is returned.logic - The object whose get method will be executed.java.lang.InterruptedExceptionpublic int joinAndEnterInternal(java.util.function.IntSupplier logic,
                                HighResolutionTime<?> time)
                         throws java.lang.InterruptedException
joinAndEnterInternal(Runnable, HighResolutionTime)
 except that the executed method is called get and an int
 is returned.logic - The object whose get method will be executed.java.lang.InterruptedExceptionpublic long joinAndEnterInternal(java.util.function.LongSupplier logic,
                                 HighResolutionTime<?> time)
                          throws java.lang.InterruptedException
joinAndEnterInternal(Runnable, HighResolutionTime)
 except that the executed method is called get and a long
 is returned.logic - The object whose get method will be executed.java.lang.InterruptedExceptionpublic double joinAndEnterInternal(java.util.function.DoubleSupplier logic,
                                   HighResolutionTime<?> time)
                            throws java.lang.InterruptedException
joinAndEnterInternal(Runnable, HighResolutionTime)
 except that the executed method is called get and a double
 is returned.logic - The object whose get method will be executed.java.lang.InterruptedExceptionpublic void executeInArea(java.lang.Runnable logic)
                   throws InaccessibleAreaException
logic parameter using
 this memory area as the current allocation context. This method
 behaves as if it moves the allocation context down the scope stack
 to the occurrence of this.executeInArea in class MemoryArealogic - The runnable object whose run() method should
          be executed.IllegalTaskStateException - when the execution context
           is not an instance of Schedulable.InaccessibleAreaException - when the memory area is not in
           the schedulable's scope stack.StaticIllegalArgumentException - when the execution context is an
         instance of Schedulable schedulable and
         logic is null.public <T> T executeInArea(java.util.function.Supplier<T> logic)
                    throws InaccessibleAreaException
logic parameter using
 this memory area as the current allocation context. This method
 behaves as if it moves the allocation context down the scope stack
 to the occurrence of this.executeInArea in class MemoryArealogic - The runnable object whose run() method should
          be executed.get() method.IllegalTaskStateException - when the execution context
           is not an instance of Schedulable.InaccessibleAreaException - when the memory area is not in
           the schedulable's scope stack.StaticIllegalArgumentException - when the execution context is an
         instance of Schedulable schedulable and
         logic is null.public int executeInArea(java.util.function.IntSupplier logic)
                  throws InaccessibleAreaException
logic parameter using
 this memory area as the current allocation context. This method
 behaves as if it moves the allocation context down the scope stack
 to the occurrence of this.executeInArea in class MemoryArealogic - The runnable object whose run() method should
          be executed.getAsInt() method.IllegalTaskStateException - when the execution context
           is not an instance of Schedulable.InaccessibleAreaException - when the memory area is not in
           the schedulable's scope stack.StaticIllegalArgumentException - when the execution context is an
         instance of Schedulable schedulable and
         logic is null.public long executeInArea(java.util.function.LongSupplier logic)
                   throws InaccessibleAreaException
logic parameter using
 this memory area as the current allocation context. This method
 behaves as if it moves the allocation context down the scope stack
 to the occurrence of this.executeInArea in class MemoryArealogic - The runnable object whose run() method should
          be executed.getAsLong() method.IllegalTaskStateException - when the execution context
           is not an instance of Schedulable.InaccessibleAreaException - when the memory area is not in
           the schedulable's scope stack.StaticIllegalArgumentException - when the execution context is an
         instance of Schedulable schedulable and
         logic is null.public double executeInArea(java.util.function.DoubleSupplier logic)
                     throws InaccessibleAreaException
logic parameter using
 this memory area as the current allocation context. This method
 behaves as if it moves the allocation context down the scope stack
 to the occurrence of this.executeInArea in class MemoryArealogic - The runnable object whose run() method should
          be executed.getAsDouble() method.IllegalTaskStateException - when the execution context
           is not an instance of Schedulable.InaccessibleAreaException - when the memory area is not in
           the schedulable's scope stack.StaticIllegalArgumentException - when the execution context is an
         instance of Schedulable schedulable and
         logic is null.public boolean executeInArea(java.util.function.BooleanSupplier logic)
                      throws InaccessibleAreaException
logic parameter using
 this memory area as the current allocation context. This method
 behaves as if it moves the allocation context down the scope stack
 to the occurrence of this.executeInArea in class MemoryArealogic - The runnable object whose run() method should
          be executed.getAsBoolean() method.IllegalTaskStateException - when the execution context
           is not an instance of Schedulable.InaccessibleAreaException - when the memory area is not in
           the schedulable's scope stack.StaticIllegalArgumentException - when the execution context is an
         instance of Schedulable schedulable and
         logic is null.aicas GmbH, Karlsruhe, Germany —www.aicas.com
Copyright © 2001-2021 aicas GmbH. All Rights Reserved.