From b6ee487efa490a9dffdde84a7b44d6aa845f7b2c Mon Sep 17 00:00:00 2001 From: Jules Ivanic Date: Tue, 29 Aug 2023 21:58:16 +0400 Subject: [PATCH] Improve performances by reducing contention (#13) --- .../uuid/internals/UUIDGeneratorBuilder.scala | 44 +++++++++---------- 1 file changed, 22 insertions(+), 22 deletions(-) diff --git a/zio-uuid/src/main/scala/zio/uuid/internals/UUIDGeneratorBuilder.scala b/zio-uuid/src/main/scala/zio/uuid/internals/UUIDGeneratorBuilder.scala index 8196a6f..5079525 100644 --- a/zio-uuid/src/main/scala/zio/uuid/internals/UUIDGeneratorBuilder.scala +++ b/zio-uuid/src/main/scala/zio/uuid/internals/UUIDGeneratorBuilder.scala @@ -21,28 +21,28 @@ private[zio] object UUIDGeneratorBuilder { builder: UUIDBuilder[UUIDvX], ): UIO[UUIDvX] = for { - random <- random.nextLong - uuid <- mutex.withPermit { - for { - timestamp <- clock.currentTime(TimeUnit.MILLISECONDS) - modifiedState <- state.modify { currentState => - // currentTime clock may run backward - val actualTimestamp = Math.max(currentState.lastUsedEpochMillis, timestamp) - val sequence = - if (currentState.lastUsedEpochMillis == actualTimestamp) { - currentState.sequence + 1 - } else 0L - - val newState = GeneratorState(lastUsedEpochMillis = actualTimestamp, sequence = sequence) - (newState, newState) - } - } yield builder( - modifiedState.lastUsedEpochMillis, - modifiedState.sequence, - random, - ) - } - } yield uuid + modifiedState <- mutex.withPermit { + for { + timestamp <- clock.currentTime(TimeUnit.MILLISECONDS) + modifiedState <- state.modify { currentState => + // currentTime clock may run backward + val actualTimestamp = Math.max(currentState.lastUsedEpochMillis, timestamp) + val sequence = + if (currentState.lastUsedEpochMillis == actualTimestamp) { + currentState.sequence + 1 + } else 0L + + val newState = GeneratorState(lastUsedEpochMillis = actualTimestamp, sequence = sequence) + (newState, newState) + } + } yield modifiedState + } + random <- random.nextLong + } yield builder( + modifiedState.lastUsedEpochMillis, + modifiedState.sequence, + random, + ) // noinspection YieldingZIOEffectInspection def buildGenerator[UUIDvX](builder: UUIDBuilder[UUIDvX]): UIO[UIO[UUIDvX]] =