Does an object always see its latest internal state irrespective of thread?

前端 未结 3 1962
旧巷少年郎
旧巷少年郎 2021-02-20 00:15

Let\'s say I have a runnable with a simple integer count variable which is incremented every time runnable runs. One instance of this object is submitted to run periodically in

3条回答
  •  傲寒
    傲寒 (楼主)
    2021-02-20 00:42

    Does an object always see its latest internal state irrespective of thread?

    Just to be clear for the purposes of this question and its answers, an object doesn't do anything; it's just memory. Threads are the executing entity. It's misleading to say does an object see whatever. It's the thread that's doing the seeing/reading of object state.

    This isn't specified in the javadoc, but

    Executors.newScheduledThreadPool(5);
    

    returns a ScheduledThreadPoolExecutor.

    Your code is using

    executorService.scheduleWithFixedDelay(counter, 1, 1, TimeUnit.SECONDS);
    

    The javadoc for ScheduledThreadPoolExecutor#scheduledWithFixedDelay states

    Submits a periodic action that becomes enabled first after the given initial delay, and subsequently with the given delay between the termination of one execution and the commencement of the next.

    The class javadoc further clarifies

    Successive executions of a periodic task scheduled via scheduleAtFixedRate or scheduleWithFixedDelay do not overlap. While different executions may be performed by different threads, the effects of prior executions happen-before those of subsequent ones.

    As such, each execution of Counter#run is guaranteed to see the value of count after it's been incremented by the previous execution. For example, the third execution will read a count value of 2 before it performs its increment.

    You don't need volatile or any other additional synchronization mechanism for this specific use case.

提交回复
热议问题