[infinispan-dev] [Discussion] TimeService implementation
Mircea Markus
mmarkus at redhat.com
Thu May 2 07:49:14 EDT 2013
On 1 May 2013, at 16:04, Sanne Grinovero wrote:
>>>> The TimeService interface is going to replace all the System.nanoTime()
>>>> and System.currentTimeMillis() in the code and it will allow to replace
>>>> in the test suite in order to provide a better control over the time
>>>> dependent code (if needed).
>>>>
>>>> The objective of this email is to discuss possible implementation and
>>>> interface that will cover the needs of everybody (or at least try it).
>>>> Later I'll create a JIRA and start the implementation (except if someone
>>>> really wants to implement it :P)
>>>>
>>>> * Interface:
>>>>
>>>> //return the current time in nanoseconds and milliseconds respectively
>>>> long nowNanos()
>>>> long nowMillis()
>>> What about time() and wallClockTime() with overloaded methods time(TimeUnit) and wallClockTime(TimeUnit)?
>>
>> what is the semantic of wallClockTime()? I'm assuming that time()
>> returns the current time in nanoseconds...
>
> There are at least two ways to use a Clock service, as there are
> different methods to get the "time" and different concepts of "time"
> depending on what your purpose is.
>
> For example you should never use two invocations of
> System.currentTimeMillis() to measure time intervals; it's generally
> less accurate but also it is affected by system clock changes, while
> nanoTime() is not. The underlying system calls are different, and
> depending on the platform the precision guarantees are different and
> in some cases the different precision guarantee has a significant
> impact on runtime performance of the invocation, for example not all
> can be JIT optimized.
>
> Most of the time we want to use nanoTime(), for example for metrics,
> but its precision is valid only in the scope of the machine it's
> executed on, so this value is meaningless for something which needs to
> be shared with other nodes.. complex, and we might want to switch
> implementation for certain use cases depending on the cluster mode.
>
> In other words: the method invoker needs to make it very clear what
> its goal is, what it wants to do with the requested "long" as it's not
> just a simple universally valid primitive.
Thanks for the very nice explanation Sanne.
So as a rule:
- use nanoTime for measuring duration on the same JVM (time() method mentioned below)
- currentTimeMillis for the wall-clock (wallClockTime() method)
Cheers,
--
Mircea Markus
Infinispan lead (www.infinispan.org)
More information about the infinispan-dev
mailing list